]> xenbits.xensource.com Git - people/jgross/xen.git/commitdiff
x86emul: avoid assembler warning about .type not taking effect in test harness
authorJan Beulich <jbeulich@suse.com>
Mon, 3 Aug 2020 14:27:22 +0000 (16:27 +0200)
committerJan Beulich <jbeulich@suse.com>
Mon, 3 Aug 2020 14:27:22 +0000 (16:27 +0200)
gcc re-orders top level blocks by default when optimizing. This
re-ordering results in all our .type directives to get emitted to the
assembly file first, followed by gcc's. The assembler warns about
attempts to change the type of a symbol when it was already set (and
when there's no intervening setting to "notype").

Signed-off-by: Jan Beulich <jbeulich@suse.com>
Acked-by: Andrew Cooper <andrew.cooper3@citrix.com>
tools/tests/x86_emulator/Makefile

index 48b3e6dce12e2957b7f83dd1da38d4a31382e686..7b07c31bbde43213c90adb51771a8bdb43d33d7e 100644 (file)
@@ -295,4 +295,9 @@ x86-emulate.o cpuid.o test_x86_emulator.o evex-disp8.o predicates.o wrappers.o:
 x86-emulate.o: x86_emulate/x86_emulate.c
 x86-emulate.o: HOSTCFLAGS += -D__XEN_TOOLS__
 
+# 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.
+$(call cc-option-add,HOSTCFLAGS-toplevel,HOSTCC,-fno-toplevel-reorder)
+test_x86_emulator.o: HOSTCFLAGS += $(HOSTCFLAGS-toplevel)
+
 test_x86_emulator.o: $(addsuffix .h,$(TESTCASES)) $(addsuffix -opmask.h,$(OPMASK))