1e093256dSMark Brown# SPDX-License-Identifier: GPL-2.0
2e093256dSMark Brown
3e093256dSMark BrownCFLAGS += -I../../../../../usr/include/
4212b0426SMark BrownTEST_GEN_PROGS := sve-ptrace sve-probe-vls vec-syscfg za-fork za-ptrace
5*a59f7a7fSMark BrownTEST_GEN_PROGS_EXTENDED := fp-pidbench fpsimd-test \
6a0f2eb64SMark Brown	rdvl-sme rdvl-sve \
7*a59f7a7fSMark Brown	sve-test \
8*a59f7a7fSMark Brown	ssve-test \
9*a59f7a7fSMark Brown	za-test \
1077108610SMark Brown	vlset
11*a59f7a7fSMark BrownTEST_PROGS_EXTENDED := fpsimd-stress sve-stress ssve-stress za-stress
12e093256dSMark Brown
13212b0426SMark Brown# Build with nolibc to avoid effects due to libc's clone() support
142c94ebedSMark Brownfp-pidbench: fp-pidbench.S asm-utils.o
152c94ebedSMark Brown	$(CC) -nostdlib $^ -o $@
16260ea4baSMark Brownfpsimd-test: fpsimd-test.o asm-utils.o
17e093256dSMark Brown	$(CC) -nostdlib $^ -o $@
18a0f2eb64SMark Brownrdvl-sme: rdvl-sme.o rdvl.o
1977108610SMark Brownrdvl-sve: rdvl-sve.o rdvl.o
20eab281e3SMark Brownsve-ptrace: sve-ptrace.o
21b43ab36aSMark Brownsve-probe-vls: sve-probe-vls.o rdvl.o
22260ea4baSMark Brownsve-test: sve-test.o asm-utils.o
23e093256dSMark Brown	$(CC) -nostdlib $^ -o $@
244126bde0SMark Brownssve-test: sve-test.S asm-utils.o
254126bde0SMark Brown	$(CC) -DSSVE -nostdlib $^ -o $@
2695cf3f23SMark Brownvec-syscfg: vec-syscfg.o rdvl.o
27e093256dSMark Brownvlset: vlset.o
28212b0426SMark Brownza-fork: za-fork.o za-fork-asm.o
29212b0426SMark Brown	$(CC) -nostdlib -static $^ -o $@ -lgcc
30212b0426SMark Brownza-fork.o: za-fork.c
31212b0426SMark Brown	$(CC) -c -fno-asynchronous-unwind-tables -fno-ident -s -Os -nostdlib \
32212b0426SMark Brown		-include ../../../../include/nolibc/nolibc.h \
33212b0426SMark Brown		-ffreestanding -Wall $^ -o $@
345aa45cc5SMark Brownza-test: za-test.o asm-utils.o
355aa45cc5SMark Brown	$(CC) -nostdlib $^ -o $@
3686c8888fSMark Brownza-ptrace: za-ptrace.o
37e093256dSMark Brown
38e093256dSMark Browninclude ../../lib.mk
39