On 4/5/24 1:44 PM, Dev Jain wrote: > Add arm target, individual Makefile targets, and instructions to build the > tests. > > Signed-off-by: Dev Jain <dev.jain@xxxxxxx> > --- > tools/testing/selftests/Makefile | 1 + > tools/testing/selftests/arm/Makefile | 57 +++++++++++++++++++++ > tools/testing/selftests/arm/README | 31 +++++++++++ > tools/testing/selftests/arm/elf/Makefile | 6 +++ > tools/testing/selftests/arm/mm/Makefile | 6 +++ > tools/testing/selftests/arm/signal/Makefile | 30 +++++++++++ > 6 files changed, 131 insertions(+) > create mode 100644 tools/testing/selftests/arm/Makefile > create mode 100644 tools/testing/selftests/arm/README > create mode 100644 tools/testing/selftests/arm/elf/Makefile > create mode 100644 tools/testing/selftests/arm/mm/Makefile > create mode 100644 tools/testing/selftests/arm/signal/Makefile Add one recursive .gitignore file or multiple .gitignore files and put generated object files in it to avoid clutter of generated objects in git history. > > diff --git a/tools/testing/selftests/Makefile b/tools/testing/selftests/Makefile > index 15b6a111c3be..8478d94cda4c 100644 > --- a/tools/testing/selftests/Makefile > +++ b/tools/testing/selftests/Makefile > @@ -1,6 +1,7 @@ > # SPDX-License-Identifier: GPL-2.0 > TARGETS += alsa > TARGETS += amd-pstate > +TARGETS += arm > TARGETS += arm64 > TARGETS += bpf > TARGETS += breakpoints > diff --git a/tools/testing/selftests/arm/Makefile b/tools/testing/selftests/arm/Makefile > new file mode 100644 > index 000000000000..039224bc006e > --- /dev/null > +++ b/tools/testing/selftests/arm/Makefile > @@ -0,0 +1,57 @@ > +# SPDX-License-Identifier: GPL-2.0 > + > +# When ARCH not overridden for crosscompiling, lookup machine > +ARCH ?= $(shell uname -m 2>/dev/null || echo not) > + > +ifneq (,$(filter $(ARCH),aarch64 arm64 arm armv7l armv8l)) > +ARM_SUBTARGETS ?= mm signal elf > +else > +ARM_SUBTARGETS := > +endif > + > +CFLAGS := -Wall -O2 -g -static > + > +# A proper top_srcdir is needed by KSFT(lib.mk) > +top_srcdir = $(realpath ../../../../) > + > +# Additional include paths needed by kselftest.h and local headers > +CFLAGS += -I$(top_srcdir)/tools/testing/selftests/ > + > +CFLAGS += -I$(top_srcdir)/tools/include Please use KHDR_INCLUDE instead of using absolute path > + > +export CFLAGS > +export top_srcdir > + > +all: > + @for DIR in $(ARM_SUBTARGETS); do \ > + BUILD_TARGET=$(OUTPUT)/$$DIR; \ > + mkdir -p $$BUILD_TARGET; \ > + make OUTPUT=$$BUILD_TARGET -C $$DIR $@; \ > + done > + > +install: all > + @for DIR in $(ARM_SUBTARGETS); do \ > + BUILD_TARGET=$(OUTPUT)/$$DIR; \ > + make OUTPUT=$$BUILD_TARGET -C $$DIR $@; \ > + done > + > +run_tests: all > + @for DIR in $(ARM_SUBTARGETS); do \ > + BUILD_TARGET=$(OUTPUT)/$$DIR; \ > + make OUTPUT=$$BUILD_TARGET -C $$DIR $@; \ > + done > + > +# Avoid any output on non arm on emit_tests > +emit_tests: > + @for DIR in $(ARM_SUBTARGETS); do \ > + BUILD_TARGET=$(OUTPUT)/$$DIR; \ > + make OUTPUT=$$BUILD_TARGET -C $$DIR $@; \ > + done > + > +clean: > + @for DIR in $(ARM_SUBTARGETS); do \ > + BUILD_TARGET=$(OUTPUT)/$$DIR; \ > + make OUTPUT=$$BUILD_TARGET -C $$DIR $@; \ > + done > + > +.PHONY: all clean install run_tests emit_tests > diff --git a/tools/testing/selftests/arm/README b/tools/testing/selftests/arm/README > new file mode 100644 > index 000000000000..1a05c043d7ee > --- /dev/null > +++ b/tools/testing/selftests/arm/README > @@ -0,0 +1,31 @@ > +KSelfTest ARM > +=============== > + > +- This is a series of compatibility tests, wherein the source files are > + built statically into a 32 bit ELF; they should pass on both 32 and 64 > + bit kernels. They are not built or run but just skipped completely when > + env-variable ARCH is found to be different than 'arm64' or 'arm' and > + `uname -m` reports other than 'aarch64', 'armv7l' or 'armv8l'. > + > +- Please ensure that the test kernel is built with CONFIG_COMPAT enabled. Please create a config file and put all the per-requisite configurations in that. For example, look at tools/testing/selftests/mm/config > + > +- Holding true the above, ARM KSFT tests can be run within the KSelfTest > + framework using standard Linux top-level-makefile targets. Please set > + $(CROSS_COMPILE) to 'arm-linux-gnueabi-' or 'arm-linux-gnueabihf-'. > + > + $ make TARGETS=arm kselftest-clean > + $ make $(CROSS_COMPILE) TARGETS=arm kselftest > + > + or > + > + $ make $(CROSS_COMPILE) -C tools/testing/selftests TARGETS=arm \ > + INSTALL_PATH=<your-installation-path> install > + > + or, alternatively, only specific arm/ subtargets can be picked: > + > + $ make $(CROSS_COMPILE) -C tools/testing/selftests TARGETS=arm \ > + ARM_SUBTARGETS="signal" INSTALL_PATH=<your-installation-path> \ > + install > + > + Further details on building and running KFST can be found in: > + Documentation/dev-tools/kselftest.rst Thanks for this well written documentation. > diff --git a/tools/testing/selftests/arm/elf/Makefile b/tools/testing/selftests/arm/elf/Makefile > new file mode 100644 > index 000000000000..86636fe02994 > --- /dev/null > +++ b/tools/testing/selftests/arm/elf/Makefile > @@ -0,0 +1,6 @@ > +# SPDX-License-Identifier: GPL-2.0 > +# Copyright (C) 2024 ARM Limited > + > +TEST_GEN_PROGS := parse_elf > + > +include ../../lib.mk > diff --git a/tools/testing/selftests/arm/mm/Makefile b/tools/testing/selftests/arm/mm/Makefile > new file mode 100644 > index 000000000000..d8bfa45df98c > --- /dev/null > +++ b/tools/testing/selftests/arm/mm/Makefile > @@ -0,0 +1,6 @@ > +# SPDX-License-Identifier: GPL-2.0 > +# Copyright (C) 2024 ARM Limited > + > +TEST_GEN_PROGS := compat_va > + > +include ../../lib.mk > diff --git a/tools/testing/selftests/arm/signal/Makefile b/tools/testing/selftests/arm/signal/Makefile > new file mode 100644 > index 000000000000..3540a25de75a > --- /dev/null > +++ b/tools/testing/selftests/arm/signal/Makefile > @@ -0,0 +1,30 @@ > +# SPDX-License-Identifier: GPL-2.0 > +# Copyright (C) 2024 ARM Limited > + > +# Additional include paths needed by kselftest.h and local headers > +CFLAGS += -D_GNU_SOURCE -std=gnu99 -I. > + > +SRCS := $(filter-out testcases/testcases.c,$(wildcard testcases/*.c)) > +PROGS := $(patsubst %.c,%,$(SRCS)) > + > +# Generated binaries to be installed by top KSFT script > +TEST_GEN_PROGS := $(notdir $(PROGS)) > + > +# Get Kernel headers installed and use them. > + > +# Including KSFT lib.mk here will also mangle the TEST_GEN_PROGS list > +# to account for any OUTPUT target-dirs optionally provided by > +# the toplevel makefile > +include ../../lib.mk > + > +$(TEST_GEN_PROGS): $(PROGS) > + cp $(PROGS) $(OUTPUT)/ > + > +# Common test-unit targets to build common-layout test-cases executables > +# Needs secondary expansion to properly include the testcase c-file in pre-reqs > +COMMON_SOURCES := test_signals.c test_signals_utils.c > +COMMON_HEADERS := test_signals.h test_signals_utils.h > + > +.SECONDEXPANSION: > +$(PROGS): $$@.c ${COMMON_SOURCES} ${COMMON_HEADERS} > + $(CC) $(CFLAGS) ${@}.c ${COMMON_SOURCES} -o $@ -- BR, Muhammad Usama Anjum