[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [PATCH v3] x86emul: build with -Os
Emulator code is large and involving it in guest operations cannot be expected to be fast anyway. Help binary size as well as, for release builds at least, compile time by building all involved code with size optimization, independent of the build being a debug or a release one. The size savings observed in a release build (with AMX and KeyLocker code in place on top of what's upstream) are above 48k of .text, with gcc 11. To keep what is being tested similar to what's in the hypervisor, apply the override to test and fuzzing harnesses as well (but affecting only the core emulator files, not any auxiliary ones). Signed-off-by: Jan Beulich <jbeulich@xxxxxxxx> --- Of course if we were to gain a Kconfig control for selecting the optimization level, the override done here may want to be controllable that way as well then. --- v3: Also apply to test and fuzzing harnesses. v2: New. --- a/tools/fuzz/x86_instruction_emulator/Makefile +++ b/tools/fuzz/x86_instruction_emulator/Makefile @@ -39,6 +39,10 @@ x86-emulate.h: x86_emulate/x86_emulate.h x86-emulate.o x86-emulate-cov.o: x86-emulate.h x86_emulate/x86_emulate.c x86_emulate/private.h fuzz-emul.o fuzz-emul-cov.o wrappers.o: x86-emulate.h +x86-emulate.o x86-emulate-cov.o: CFLAGS += -Os +$(filter x86_emulate/%.o,$(OBJS)): CFLAGS += -Os +$(patsubst %.o,%-cov.o,$(filter x86_emulate/%.o,$(OBJS))): CFLAGS += -Os + $(filter x86_emulate/%.o,$(OBJS)): x86_emulate/%.o: x86_emulate/%.c x86_emulate/private.h $(x86_emulate.h) $(CC) $(CPPFLAGS) $(CFLAGS) $(CFLAGS_$*.o) -c -o $@ $< $(APPEND_CFLAGS) --- a/tools/tests/x86_emulator/Makefile +++ b/tools/tests/x86_emulator/Makefile @@ -298,7 +298,7 @@ $(OBJS): %.o: %.c $(x86_emulate.h) $(HOSTCC) $(HOSTCFLAGS) -c -g -o $@ $< x86-emulate.o: x86_emulate/x86_emulate.c -x86-emulate.o x86_emulate/%.o: HOSTCFLAGS += -D__XEN_TOOLS__ +x86-emulate.o x86_emulate/%.o: HOSTCFLAGS += -D__XEN_TOOLS__ -Os # In order for our custom .type assembler directives to reliably land after # gcc's, we need to keep it from re-ordering top-level constructs. --- a/xen/arch/x86/Makefile +++ b/xen/arch/x86/Makefile @@ -89,6 +89,7 @@ hostprogs-y += efi/mkreloc # Allows usercopy.c to include itself $(obj)/usercopy.o: CFLAGS-y += -iquote . +$(obj)/x86_emulate.o: CFLAGS-y += -Os ifneq ($(CONFIG_HVM),y) $(obj)/x86_emulate.o: CFLAGS-y += -Wno-unused-label endif --- a/xen/arch/x86/x86_emulate/Makefile +++ b/xen/arch/x86/x86_emulate/Makefile @@ -1,3 +1,5 @@ +CFLAGS-y += -Os + obj-y += 0f01.o obj-y += 0fae.o obj-y += 0fc7.o
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |