Makefile.target (2309B)
1 # -*- Mode: makefile -*- 2 # 3 # ARM - included from tests/tcg/Makefile 4 # 5 6 ARM_SRC=$(SRC_PATH)/tests/tcg/arm 7 8 # Set search path for all sources 9 VPATH += $(ARM_SRC) 10 11 float_madds: CFLAGS+=-mfpu=neon-vfpv4 12 13 # Basic Hello World 14 ARM_TESTS = hello-arm 15 hello-arm: CFLAGS+=-marm -ffreestanding 16 hello-arm: LDFLAGS+=-nostdlib 17 18 # IWMXT floating point extensions 19 ARM_TESTS += test-arm-iwmmxt 20 test-arm-iwmmxt: CFLAGS+=-marm -march=iwmmxt -mabi=aapcs -mfpu=fpv4-sp-d16 21 test-arm-iwmmxt: test-arm-iwmmxt.S 22 $(CC) $(CFLAGS) $< -o $@ $(LDFLAGS) 23 24 # Float-convert Tests 25 ARM_TESTS += fcvt 26 fcvt: LDFLAGS+=-lm 27 # fcvt: CFLAGS+=-march=armv8.2-a+fp16 -mfpu=neon-fp-armv8 28 run-fcvt: fcvt 29 $(call run-test,fcvt,$(QEMU) $<) 30 $(call diff-out,fcvt,$(ARM_SRC)/fcvt.ref) 31 32 # PC alignment test 33 ARM_TESTS += pcalign-a32 34 pcalign-a32: CFLAGS+=-marm 35 36 ifeq ($(CONFIG_ARM_COMPATIBLE_SEMIHOSTING),y) 37 38 # Semihosting smoke test for linux-user 39 semihosting: CFLAGS += -mthumb 40 41 ARM_TESTS += semihosting-arm 42 semihosting-arm: CFLAGS += -marm -I$(SRC_PATH)/tests/tcg/$(TARGET_NAME) 43 semihosting-arm: semihosting.c 44 $(CC) $(CFLAGS) $(EXTRA_CFLAGS) $< -o $@ $(LDFLAGS) 45 46 run-semihosting-arm: semihosting-arm 47 $(call run-test,$<,$(QEMU) $< 2> $<.err) 48 49 run-plugin-semihosting-arm-with-%: 50 $(call run-test, $@, $(QEMU) $(QEMU_OPTS) \ 51 -plugin $(PLUGIN_LIB)/$(call extract-plugin,$@) \ 52 $(call strip-plugin,$<) 2> $<.err) 53 54 ARM_TESTS += semiconsole-arm 55 56 semiconsole: CFLAGS += -mthumb 57 58 semiconsole-arm: CFLAGS += -marm -I$(SRC_PATH)/tests/tcg/$(TARGET_NAME) 59 semiconsole-arm: semihosting.c 60 $(CC) $(CFLAGS) $(EXTRA_CFLAGS) $< -o $@ $(LDFLAGS) 61 62 run-semiconsole-arm: semiconsole-arm 63 $(call skip-test, $<, "MANUAL ONLY") 64 65 run-plugin-semiconsole-arm-with-%: 66 $(call skip-test, $<, "MANUAL ONLY") 67 68 endif 69 70 ARM_TESTS += commpage 71 72 # Vector SHA1 73 sha1-vector: CFLAGS=-O3 74 sha1-vector: sha1.c 75 $(CC) $(CFLAGS) $(EXTRA_CFLAGS) $< -o $@ $(LDFLAGS) 76 run-sha1-vector: sha1-vector run-sha1 77 $(call run-test, $<, $(QEMU) $(QEMU_OPTS) $<) 78 $(call diff-out, sha1-vector, sha1.out) 79 80 ARM_TESTS += sha1-vector 81 82 # Vector versions of sha512 (-O3 triggers vectorisation) 83 sha512-vector: CFLAGS=-O3 84 sha512-vector: sha512.c 85 $(CC) $(CFLAGS) $(EXTRA_CFLAGS) $< -o $@ $(LDFLAGS) 86 87 ARM_TESTS += sha512-vector 88 89 TESTS += $(ARM_TESTS) 90 91 # On ARM Linux only supports 4k pages 92 EXTRA_RUNS+=run-test-mmap-4096