xref: /openbmc/qemu/tests/tcg/arm/Makefile.target (revision c6e1b31b)
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