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