On Mon, Aug 19, 2019 at 04:28:30PM +0300, Jarkko Sakkinen wrote: > Recurse into a list of subdirectories defined by SUBDIRS when running > x86 selftests. Override run_tests, install, emit_tests and clean > targets to implement this behaviour. The code looks good (which doesn't say much, my Makefile knowledge is garbage), but the result is a bit odd. x86/sgx doesn't implement emit_tests (or at least test_sgx doesn't show up), while the rest of the x86 tests don't support install. AFAICT the Makefile is itself weird; it's definitely different than other selftests Makfiles. I don't see any reason to delay this patch, but it feels like something here needs to be cleaned up. > A possible alternative would be to add "x86/sgx" to TARGETS. However, > this would be problematic because detecting 64-bit build would have > to duplicated. > > The implementation is derived from the makefiles of powerpc and sparc64 > selftests. > > Signed-off-by: Jarkko Sakkinen <jarkko.sakkinen@xxxxxxxxxxxxxxx> > --- > tools/testing/selftests/x86/Makefile | 44 ++++++++++++++++++++++++++++ > 1 file changed, 44 insertions(+) > > diff --git a/tools/testing/selftests/x86/Makefile b/tools/testing/selftests/x86/Makefile > index fa07d526fe39..80571bac8ed5 100644 > --- a/tools/testing/selftests/x86/Makefile > +++ b/tools/testing/selftests/x86/Makefile > @@ -10,6 +10,8 @@ CAN_BUILD_I386 := $(shell ./check_cc.sh $(CC) trivial_32bit_program.c -m32) > CAN_BUILD_X86_64 := $(shell ./check_cc.sh $(CC) trivial_64bit_program.c) > CAN_BUILD_WITH_NOPIE := $(shell ./check_cc.sh $(CC) trivial_program.c -no-pie) > > +SUBDIRS := sgx > + > TARGETS_C_BOTHBITS := single_step_syscall sysret_ss_attrs syscall_nt test_mremap_vdso \ > check_initial_reg_state sigreturn iopl mpx-mini-test ioperm \ > protection_keys test_vdso test_vsyscall mov_ss_trap \ > @@ -59,6 +61,48 @@ endif > > ifeq ($(CAN_BUILD_X86_64),1) > all: all_64 > + @for DIR in $(SUBDIRS); do \ > + BUILD_TARGET=$(OUTPUT)/$$DIR; \ > + mkdir $$BUILD_TARGET -p; \ > + make OUTPUT=$$BUILD_TARGET -C $$DIR $@; \ > + done > + > +DEFAULT_RUN_TESTS := $(RUN_TESTS) > +override define RUN_TESTS > + $(DEFAULT_RUN_TESTS) > + @for TARGET in $(SUBDIRS); do \ > + BUILD_TARGET=$(OUTPUT)/$$TARGET; \ > + $(MAKE) OUTPUT=$$BUILD_TARGET -C $$TARGET run_tests; \ > + done; > +endef > + > +DEFAULT_INSTALL_RULE := $(INSTALL_RULE) > +override define INSTALL_RULE > + $(DEFAULT_INSTALL_RULE) > + @for TARGET in $(SUBDIRS); do \ > + BUILD_TARGET=$(OUTPUT)/$$TARGET; \ > + $(MAKE) OUTPUT=$$BUILD_TARGET -C $$TARGET install; \ > + done; > +endef > + > +DEFAULT_EMIT_TESTS := $(EMIT_TESTS) > +override define EMIT_TESTS > + $(DEFAULT_EMIT_TESTS) > + @for TARGET in $(SUBDIRS); do \ > + BUILD_TARGET=$(OUTPUT)/$$TARGET; \ > + $(MAKE) OUTPUT=$$BUILD_TARGET -s -C $$TARGET emit_tests; \ > + done; > +endef > + > +DEFAULT_CLEAN := $(CLEAN) > +override define CLEAN > + $(DEFAULT_CLEAN) > + @for TARGET in $(SUBDIRS); do \ > + BUILD_TARGET=$(OUTPUT)/$$TARGET; \ > + $(MAKE) OUTPUT=$$BUILD_TARGET -C $$TARGET clean; \ > + done; > +endef > + > TEST_PROGS += $(BINARIES_64) > EXTRA_CFLAGS += -DCAN_BUILD_64 > $(foreach t,$(TARGETS_C_64BIT_ALL),$(eval $(call gen-target-rule-64,$(t)))) > -- > 2.20.1 >