1# -*- Mode: makefile -*- 2# 3# Multiarch Tests - included from tests/tcg/Makefile.target 4# 5# These tests are plain C and built without any architecture specific code. 6# 7 8MULTIARCH_SRC=$(SRC_PATH)/tests/tcg/multiarch 9 10# Set search path for all sources 11VPATH += $(MULTIARCH_SRC) 12MULTIARCH_SRCS = $(notdir $(wildcard $(MULTIARCH_SRC)/*.c)) 13ifeq ($(filter %-linux-user, $(TARGET)),$(TARGET)) 14VPATH += $(MULTIARCH_SRC)/linux 15MULTIARCH_SRCS += $(notdir $(wildcard $(MULTIARCH_SRC)/linux/*.c)) 16endif 17MULTIARCH_TESTS = $(MULTIARCH_SRCS:.c=) 18 19# 20# The following are any additional rules needed to build things 21# 22 23 24float_%: LDFLAGS+=-lm 25float_%: float_%.c libs/float_helpers.c 26 $(CC) $(CFLAGS) $(EXTRA_CFLAGS) $< $(MULTIARCH_SRC)/libs/float_helpers.c -o $@ $(LDFLAGS) 27 28run-float_%: float_% 29 $(call run-test,$<, $(QEMU) $(QEMU_OPTS) $<) 30 $(call conditional-diff-out,$<,$(SRC_PATH)/tests/tcg/$(TARGET_NAME)/$<.ref) 31 32 33testthread: LDFLAGS+=-lpthread 34 35threadcount: LDFLAGS+=-lpthread 36 37signals: LDFLAGS+=-lrt -lpthread 38 39munmap-pthread: CFLAGS+=-pthread 40munmap-pthread: LDFLAGS+=-pthread 41 42vma-pthread: CFLAGS+=-pthread 43vma-pthread: LDFLAGS+=-pthread 44 45# The vma-pthread seems very sensitive on gitlab and we currently 46# don't know if its exposing a real bug or the test is flaky. 47ifneq ($(GITLAB_CI),) 48run-vma-pthread: vma-pthread 49 $(call skip-test, $<, "flaky on CI?") 50run-plugin-vma-pthread-with-%: vma-pthread 51 $(call skip-test, $<, "flaky on CI?") 52endif 53 54# We define the runner for test-mmap after the individual 55# architectures have defined their supported pages sizes. If no 56# additional page sizes are defined we only run the default test. 57 58# default case (host page size) 59run-test-mmap: test-mmap 60 $(call run-test, test-mmap, $(QEMU) $<, $< (default)) 61 62# additional page sizes (defined by each architecture adding to EXTRA_RUNS) 63run-test-mmap-%: test-mmap 64 $(call run-test, test-mmap-$*, $(QEMU) -p $* $<, $< ($* byte pages)) 65 66ifneq ($(HAVE_GDB_BIN),) 67GDB_SCRIPT=$(SRC_PATH)/tests/guest-debug/run-test.py 68 69run-gdbstub-sha1: sha1 70 $(call run-test, $@, $(GDB_SCRIPT) \ 71 --gdb $(HAVE_GDB_BIN) \ 72 --qemu $(QEMU) --qargs "$(QEMU_OPTS)" \ 73 --bin $< --test $(MULTIARCH_SRC)/gdbstub/sha1.py, \ 74 basic gdbstub support) 75 76run-gdbstub-qxfer-auxv-read: sha1 77 $(call run-test, $@, $(GDB_SCRIPT) \ 78 --gdb $(HAVE_GDB_BIN) \ 79 --qemu $(QEMU) --qargs "$(QEMU_OPTS)" \ 80 --bin $< --test $(MULTIARCH_SRC)/gdbstub/test-qxfer-auxv-read.py, \ 81 basic gdbstub qXfer:auxv:read support) 82 83run-gdbstub-thread-breakpoint: testthread 84 $(call run-test, $@, $(GDB_SCRIPT) \ 85 --gdb $(HAVE_GDB_BIN) \ 86 --qemu $(QEMU) --qargs "$(QEMU_OPTS)" \ 87 --bin $< --test $(MULTIARCH_SRC)/gdbstub/test-thread-breakpoint.py, \ 88 hitting a breakpoint on non-main thread) 89 90else 91run-gdbstub-%: 92 $(call skip-test, "gdbstub test $*", "need working gdb") 93endif 94EXTRA_RUNS += run-gdbstub-sha1 run-gdbstub-qxfer-auxv-read \ 95 run-gdbstub-thread-breakpoint 96 97# ARM Compatible Semi Hosting Tests 98# 99# Despite having ARM in the name we actually have several 100# architectures that implement it. We gate the tests on the feature 101# appearing in config. 102# 103ifeq ($(CONFIG_ARM_COMPATIBLE_SEMIHOSTING),y) 104VPATH += $(MULTIARCH_SRC)/arm-compat-semi 105 106# Add -I path back to TARGET_NAME for semicall.h 107semihosting: CFLAGS+=-I$(SRC_PATH)/tests/tcg/$(TARGET_NAME) 108 109run-semihosting: semihosting 110 $(call run-test,$<,$(QEMU) $< 2> $<.err) 111 112run-plugin-semihosting-with-%: 113 $(call run-test, $@, $(QEMU) $(QEMU_OPTS) \ 114 -plugin $(PLUGIN_LIB)/$(call extract-plugin,$@) \ 115 $(call strip-plugin,$<) 2> $<.err, \ 116 $< with $*) 117 118semiconsole: CFLAGS+=-I$(SRC_PATH)/tests/tcg/$(TARGET_NAME) 119 120run-semiconsole: semiconsole 121 $(call skip-test, $<, "MANUAL ONLY") 122 123run-plugin-semiconsole-with-%: 124 $(call skip-test, $<, "MANUAL ONLY") 125 126TESTS += semihosting semiconsole 127endif 128 129# Update TESTS 130TESTS += $(MULTIARCH_TESTS) 131