hw/sd/sdcard: Add emmc_cmd_SET_RELATIVE_ADDR handler (CMD3)
[qemu/armbru.git] / tests / tcg / hexagon / Makefile.target
blobe5182c01d8a0c537b41d5a280c3d2e9e55cd4cf0
1 ##
2 ##  Copyright(c) 2019-2023 Qualcomm Innovation Center, Inc. All Rights Reserved.
3 ##
4 ##  This program is free software; you can redistribute it and/or modify
5 ##  it under the terms of the GNU General Public License as published by
6 ##  the Free Software Foundation; either version 2 of the License, or
7 ##  (at your option) any later version.
8 ##
9 ##  This program is distributed in the hope that it will be useful,
10 ##  but WITHOUT ANY WARRANTY; without even the implied warranty of
11 ##  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 ##  GNU General Public License for more details.
14 ##  You should have received a copy of the GNU General Public License
15 ##  along with this program; if not, see <http://www.gnu.org/licenses/>.
18 # Hexagon doesn't support gdb, so skip the EXTRA_RUNS
19 EXTRA_RUNS =
21 CFLAGS += -Wno-incompatible-pointer-types -Wno-undefined-internal
22 CFLAGS += -fno-unroll-loops -fno-stack-protector
24 HEX_SRC=$(SRC_PATH)/tests/tcg/hexagon
25 VPATH += $(HEX_SRC)
27 %: $(HEX_SRC)/%.S $(HEX_SRC)/crt.S
28         $(CC) -static -mv67 -nostdlib $^ -o $@
30 HEX_TESTS = first
31 HEX_TESTS += hex_sigsegv
32 HEX_TESTS += misc
33 HEX_TESTS += usr
34 HEX_TESTS += preg_alias
35 HEX_TESTS += dual_stores
36 HEX_TESTS += multi_result
37 HEX_TESTS += mem_noshuf
38 HEX_TESTS += mem_noshuf_exception
39 HEX_TESTS += circ
40 HEX_TESTS += brev
41 HEX_TESTS += load_unpack
42 HEX_TESTS += load_align
43 HEX_TESTS += atomics
44 HEX_TESTS += fpstuff
45 HEX_TESTS += overflow
46 HEX_TESTS += signal_context
47 HEX_TESTS += reg_mut
48 HEX_TESTS += read_write_overlap
49 HEX_TESTS += vector_add_int
50 HEX_TESTS += scatter_gather
51 HEX_TESTS += hvx_misc
52 HEX_TESTS += hvx_histogram
53 HEX_TESTS += invalid-slots
54 HEX_TESTS += unaligned_pc
56 run-and-check-exception = $(call run-test,$2,$3 2>$2.stderr; \
57         test $$? -eq 1 && grep -q "exception $(strip $1)" $2.stderr)
59 run-invalid-slots: invalid-slots
60         $(call run-and-check-exception, 0x15, $@, $(QEMU) $(QEMU_OPTS) $<)
62 HEX_TESTS += test_abs
63 HEX_TESTS += test_bitcnt
64 HEX_TESTS += test_bitsplit
65 HEX_TESTS += test_call
66 HEX_TESTS += test_clobber
67 HEX_TESTS += test_cmp
68 HEX_TESTS += test_dotnew
69 HEX_TESTS += test_ext
70 HEX_TESTS += test_fibonacci
71 HEX_TESTS += test_hl
72 HEX_TESTS += test_hwloops
73 HEX_TESTS += test_jmp
74 HEX_TESTS += test_lsr
75 HEX_TESTS += test_mpyi
76 HEX_TESTS += test_packet
77 HEX_TESTS += test_reorder
78 HEX_TESTS += test_round
79 HEX_TESTS += test_vavgw
80 HEX_TESTS += test_vcmpb
81 HEX_TESTS += test_vcmpw
82 HEX_TESTS += test_vlsrw
83 HEX_TESTS += test_vmaxh
84 HEX_TESTS += test_vminh
85 HEX_TESTS += test_vpmpyh
86 HEX_TESTS += test_vspliceb
88 HEX_TESTS += v68_scalar
89 HEX_TESTS += v68_hvx
90 HEX_TESTS += v69_hvx
91 HEX_TESTS += v73_scalar
93 TESTS += $(HEX_TESTS)
95 atomics: atomics.c hex_test.h
96 brev: brev.c hex_test.h
97 circ: circ.c hex_test.h
98 dual_stores: dual_stores.c hex_test.h
99 fpstuff: fpstuff.c hex_test.h
100 hex_sigsegv: hex_sigsegv.c hex_test.h
101 load_align: load_align.c hex_test.h
102 load_unpack: load_unpack.c hex_test.h
103 mem_noshuf_exception: mem_noshuf_exception.c hex_test.h
104 mem_noshuf: mem_noshuf.c hex_test.h
105 misc: misc.c hex_test.h
106 multi_result: multi_result.c hex_test.h
107 overflow: overflow.c hex_test.h
108 preg_alias: preg_alias.c hex_test.h
109 read_write_overlap: read_write_overlap.c hex_test.h
110 reg_mut: reg_mut.c hex_test.h
111 unaligned_pc: unaligned_pc.c
113 # This test has to be compiled for the -mv67t target
114 usr: usr.c hex_test.h
115         $(CC) $(CFLAGS) -mv67t -O2 -Wno-inline-asm -Wno-expansion-to-defined $< -o $@ $(LDFLAGS)
117 # Build this test with -mv71 to exercise the CABAC instruction
118 misc: misc.c
119         $(CC) $(CFLAGS) -mv71 -O2 $< -o $@ $(LDFLAGS)
120 scatter_gather: CFLAGS += -mhvx
121 vector_add_int: CFLAGS += -mhvx -fvectorize
122 hvx_misc: hvx_misc.c hvx_misc.h
123 hvx_misc: CFLAGS += -mhvx
124 hvx_histogram: CFLAGS += -mhvx -Wno-gnu-folding-constant
125 v68_hvx: v68_hvx.c hvx_misc.h v6mpy_ref.c.inc
126 v68_hvx: CFLAGS += -mhvx -Wno-unused-function
127 v69_hvx: v69_hvx.c hvx_misc.h
128 v69_hvx: CFLAGS += -mhvx -Wno-unused-function
129 v73_scalar: CFLAGS += -Wno-unused-function
131 hvx_histogram: hvx_histogram.c hvx_histogram_row.S
132         $(CC) $(CFLAGS) $(CROSS_CC_GUEST_CFLAGS) $^ -o $@ $(LDFLAGS)