Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | # SPDX-License-Identifier: GPL-2.0 |
Hendrik Brueckner | 618e165 | 2017-12-04 10:56:48 +0100 | [diff] [blame] | 2 | |
Mickaël Salaün | d498f87 | 2017-02-11 23:20:23 +0100 | [diff] [blame] | 3 | LIBDIR := ../../../lib |
Zi Shen Lim | e8f1f34 | 2017-03-19 23:03:14 -0700 | [diff] [blame] | 4 | BPFDIR := $(LIBDIR)/bpf |
Daniel Borkmann | 02ea80b | 2017-03-31 02:24:04 +0200 | [diff] [blame] | 5 | APIDIR := ../../../include/uapi |
| 6 | GENDIR := ../../../../include/generated |
| 7 | GENHDR := $(GENDIR)/autoconf.h |
Mickaël Salaün | d498f87 | 2017-02-11 23:20:23 +0100 | [diff] [blame] | 8 | |
Daniel Borkmann | 02ea80b | 2017-03-31 02:24:04 +0200 | [diff] [blame] | 9 | ifneq ($(wildcard $(GENHDR)),) |
| 10 | GENFLAGS := -DHAVE_GENHDR |
| 11 | endif |
| 12 | |
Jiong Wang | 3ef8434 | 2019-01-26 12:26:14 -0500 | [diff] [blame] | 13 | CLANG ?= clang |
| 14 | LLC ?= llc |
| 15 | LLVM_OBJCOPY ?= llvm-objcopy |
| 16 | LLVM_READELF ?= llvm-readelf |
| 17 | BTF_PAHOLE ?= pahole |
Jakub Kicinski | d0cabbb | 2018-05-10 10:24:40 -0700 | [diff] [blame] | 18 | CFLAGS += -Wall -O2 -I$(APIDIR) -I$(LIBDIR) -I$(BPFDIR) -I$(GENDIR) $(GENFLAGS) -I../../../include |
Yonghong Song | af32efe | 2018-01-26 15:06:08 -0800 | [diff] [blame] | 19 | LDLIBS += -lcap -lelf -lrt -lpthread |
Daniel Borkmann | 5aa5bd1 | 2016-10-17 14:28:36 +0200 | [diff] [blame] | 20 | |
Jesper Dangaard Brouer | f09b2e3 | 2018-02-08 12:48:27 +0100 | [diff] [blame] | 21 | # Order correspond to 'make run_tests' order |
David S. Miller | 18b3ad9 | 2017-05-10 11:43:51 -0700 | [diff] [blame] | 22 | TEST_GEN_PROGS = test_verifier test_tag test_maps test_lru_map test_lpm_map test_progs \ |
Andrey Ignatov | 1d43688 | 2018-03-30 15:08:08 -0700 | [diff] [blame] | 23 | test_align test_verifier_log test_dev_cgroup test_tcpbpf_user \ |
Andrey Ignatov | 194db0d | 2018-07-30 17:42:31 -0700 | [diff] [blame] | 24 | test_sock test_btf test_sockmap test_lirc_mode2_user get_cgroup_id_user \ |
Roman Gushchin | 371e4fc | 2018-09-28 14:46:00 +0000 | [diff] [blame] | 25 | test_socket_cookie test_cgroup_storage test_select_reuseport test_section_names \ |
Martin KaFai Lau | e0b27b3 | 2019-02-09 23:22:28 -0800 | [diff] [blame] | 26 | test_netcnt test_tcpnotify_user test_sock_fields |
Alexei Starovoitov | 6882804 | 2017-03-30 21:45:41 -0700 | [diff] [blame] | 27 | |
Jiong Wang | 3ef8434 | 2019-01-26 12:26:14 -0500 | [diff] [blame] | 28 | BPF_OBJ_FILES = \ |
| 29 | test_xdp_redirect.o test_xdp_meta.o sockmap_parse_prog.o \ |
| 30 | sockmap_verdict_prog.o dev_cgroup.o sample_ret0.o \ |
| 31 | test_tcpnotify_kern.o sample_map_ret0.o test_tcpbpf_kern.o \ |
| 32 | sockmap_tcp_msg_prog.o connect4_prog.o connect6_prog.o \ |
| 33 | test_btf_haskv.o test_btf_nokv.o test_sockmap_kern.o \ |
| 34 | test_tunnel_kern.o test_sockhash_kern.o test_lwt_seg6local.o \ |
| 35 | sendmsg4_prog.o sendmsg6_prog.o test_lirc_mode2_kern.o \ |
Andrey Ignatov | 5ecd8c2 | 2018-08-12 10:49:30 -0700 | [diff] [blame] | 36 | get_cgroup_id_kern.o socket_cookie_prog.o test_select_reuseport_kern.o \ |
Jiong Wang | 3ef8434 | 2019-01-26 12:26:14 -0500 | [diff] [blame] | 37 | test_skb_cgroup_id_kern.o bpf_flow.o netcnt_prog.o test_xdp_vlan.o \ |
Martin KaFai Lau | e0b27b3 | 2019-02-09 23:22:28 -0800 | [diff] [blame] | 38 | xdp_dummy.o test_map_in_map.o test_spin_lock.o test_map_lock.o \ |
| 39 | test_sock_fields_kern.o |
Daniel Borkmann | 5aa5bd1 | 2016-10-17 14:28:36 +0200 | [diff] [blame] | 40 | |
Jiong Wang | 3ef8434 | 2019-01-26 12:26:14 -0500 | [diff] [blame] | 41 | # Objects are built with default compilation flags and with sub-register |
| 42 | # code-gen enabled. |
| 43 | BPF_OBJ_FILES_DUAL_COMPILE = \ |
| 44 | test_pkt_access.o test_pkt_access.o test_xdp.o test_adjust_tail.o \ |
| 45 | test_l4lb.o test_l4lb_noinline.o test_xdp_noinline.o test_tcp_estats.o \ |
| 46 | test_obj_id.o test_pkt_md_access.o test_tracepoint.o \ |
| 47 | test_stacktrace_map.o test_stacktrace_map.o test_stacktrace_build_id.o \ |
| 48 | test_stacktrace_build_id.o test_get_stack_rawtp.o \ |
| 49 | test_get_stack_rawtp.o test_tracepoint.o test_sk_lookup_kern.o \ |
| 50 | test_queue_map.o test_stack_map.o |
| 51 | |
| 52 | TEST_GEN_FILES = $(BPF_OBJ_FILES) $(BPF_OBJ_FILES_DUAL_COMPILE) |
| 53 | |
| 54 | # Also test sub-register code-gen if LLVM + kernel both has eBPF v3 processor |
| 55 | # support which is the first version to contain both ALU32 and JMP32 |
| 56 | # instructions. |
| 57 | SUBREG_CODEGEN := $(shell echo "int cal(int a) { return a > 0; }" | \ |
| 58 | $(CLANG) -target bpf -O2 -emit-llvm -S -x c - -o - | \ |
| 59 | $(LLC) -mattr=+alu32 -mcpu=probe 2>&1 | \ |
| 60 | grep 'if w') |
| 61 | ifneq ($(SUBREG_CODEGEN),) |
| 62 | TEST_GEN_FILES += $(patsubst %.o,alu32/%.o, $(BPF_OBJ_FILES_DUAL_COMPILE)) |
| 63 | endif |
| 64 | |
Jesper Dangaard Brouer | f09b2e3 | 2018-02-08 12:48:27 +0100 | [diff] [blame] | 65 | # Order correspond to 'make run_tests' order |
| 66 | TEST_PROGS := test_kmod.sh \ |
| 67 | test_libbpf.sh \ |
| 68 | test_xdp_redirect.sh \ |
| 69 | test_xdp_meta.sh \ |
Andrey Ignatov | 622adaf | 2018-03-30 15:08:06 -0700 | [diff] [blame] | 70 | test_offload.py \ |
William Tu | 933a741 | 2018-04-26 14:01:39 -0700 | [diff] [blame] | 71 | test_sock_addr.sh \ |
Mathieu Xhonneux | c99a84e | 2018-05-20 14:58:17 +0100 | [diff] [blame] | 72 | test_tunnel.sh \ |
Sean Young | 6bdd533 | 2018-05-27 12:24:10 +0100 | [diff] [blame] | 73 | test_lwt_seg6local.sh \ |
Andrey Ignatov | 5ecd8c2 | 2018-08-12 10:49:30 -0700 | [diff] [blame] | 74 | test_lirc_mode2.sh \ |
Petar Penkov | 50b3ed5 | 2018-09-14 07:46:22 -0700 | [diff] [blame] | 75 | test_skb_cgroup_id.sh \ |
Jesper Dangaard Brouer | 97396ff | 2018-10-09 12:04:53 +0200 | [diff] [blame] | 76 | test_flow_dissector.sh \ |
| 77 | test_xdp_vlan.sh |
Daniel Borkmann | 5aa5bd1 | 2016-10-17 14:28:36 +0200 | [diff] [blame] | 78 | |
Anders Roxell | f98937c | 2019-01-08 10:23:03 +0100 | [diff] [blame] | 79 | TEST_PROGS_EXTENDED := with_addr.sh \ |
Stanislav Fomichev | 1be72f2 | 2019-01-14 09:41:41 -0800 | [diff] [blame] | 80 | with_tunnels.sh \ |
Anders Roxell | f98937c | 2019-01-08 10:23:03 +0100 | [diff] [blame] | 81 | tcp_client.py \ |
| 82 | tcp_server.py |
Anders Roxell | ef4ab84 | 2018-10-10 16:27:04 +0200 | [diff] [blame] | 83 | |
Jesper Dangaard Brouer | f09b2e3 | 2018-02-08 12:48:27 +0100 | [diff] [blame] | 84 | # Compile but not part of 'make run_tests' |
Petar Penkov | 50b3ed5 | 2018-09-14 07:46:22 -0700 | [diff] [blame] | 85 | TEST_GEN_PROGS_EXTENDED = test_libbpf_open test_sock_addr test_skb_cgroup_id_user \ |
| 86 | flow_dissector_load test_flow_dissector |
Jesper Dangaard Brouer | f09b2e3 | 2018-02-08 12:48:27 +0100 | [diff] [blame] | 87 | |
Zi Shen Lim | e8f1f34 | 2017-03-19 23:03:14 -0700 | [diff] [blame] | 88 | include ../lib.mk |
Alexei Starovoitov | 1da8ac7 | 2017-03-10 22:05:55 -0800 | [diff] [blame] | 89 | |
Jiong Wang | 3ef8434 | 2019-01-26 12:26:14 -0500 | [diff] [blame] | 90 | # NOTE: $(OUTPUT) won't get default value if used before lib.mk |
| 91 | TEST_CUSTOM_PROGS = $(OUTPUT)/urandom_read |
| 92 | all: $(TEST_CUSTOM_PROGS) |
| 93 | |
| 94 | $(OUTPUT)/urandom_read: $(OUTPUT)/%: %.c |
| 95 | $(CC) -o $@ -static $< -Wl,--build-id |
| 96 | |
Jesper Dangaard Brouer | 41757dc | 2018-02-13 14:19:15 +0100 | [diff] [blame] | 97 | BPFOBJ := $(OUTPUT)/libbpf.a |
Zi Shen Lim | e8f1f34 | 2017-03-19 23:03:14 -0700 | [diff] [blame] | 98 | |
| 99 | $(TEST_GEN_PROGS): $(BPFOBJ) |
| 100 | |
Jesper Dangaard Brouer | f09b2e3 | 2018-02-08 12:48:27 +0100 | [diff] [blame] | 101 | $(TEST_GEN_PROGS_EXTENDED): $(OUTPUT)/libbpf.a |
| 102 | |
Jesper Dangaard Brouer | 41757dc | 2018-02-13 14:19:15 +0100 | [diff] [blame] | 103 | $(OUTPUT)/test_dev_cgroup: cgroup_helpers.c |
Andrey Ignatov | 5ecd8c2 | 2018-08-12 10:49:30 -0700 | [diff] [blame] | 104 | $(OUTPUT)/test_skb_cgroup_id_user: cgroup_helpers.c |
Andrey Ignatov | 1d43688 | 2018-03-30 15:08:08 -0700 | [diff] [blame] | 105 | $(OUTPUT)/test_sock: cgroup_helpers.c |
Andrey Ignatov | e50b0a6 | 2018-03-30 15:08:03 -0700 | [diff] [blame] | 106 | $(OUTPUT)/test_sock_addr: cgroup_helpers.c |
Andrey Ignatov | 194db0d | 2018-07-30 17:42:31 -0700 | [diff] [blame] | 107 | $(OUTPUT)/test_socket_cookie: cgroup_helpers.c |
John Fastabend | 16962b2 | 2018-04-23 14:30:38 -0700 | [diff] [blame] | 108 | $(OUTPUT)/test_sockmap: cgroup_helpers.c |
Andrey Ignatov | c65267e | 2018-07-11 17:33:35 -0700 | [diff] [blame] | 109 | $(OUTPUT)/test_tcpbpf_user: cgroup_helpers.c |
Sowmini Varadhan | 435f90a | 2018-11-07 16:12:02 -0800 | [diff] [blame] | 110 | $(OUTPUT)/test_tcpnotify_user: cgroup_helpers.c trace_helpers.c |
Yonghong Song | 173965f | 2018-04-28 22:28:15 -0700 | [diff] [blame] | 111 | $(OUTPUT)/test_progs: trace_helpers.c |
Yonghong Song | f269099 | 2018-06-03 15:59:43 -0700 | [diff] [blame] | 112 | $(OUTPUT)/get_cgroup_id_user: cgroup_helpers.c |
Roman Gushchin | 68cfa3a | 2018-08-02 14:27:29 -0700 | [diff] [blame] | 113 | $(OUTPUT)/test_cgroup_storage: cgroup_helpers.c |
Roman Gushchin | 371e4fc | 2018-09-28 14:46:00 +0000 | [diff] [blame] | 114 | $(OUTPUT)/test_netcnt: cgroup_helpers.c |
Martin KaFai Lau | e0b27b3 | 2019-02-09 23:22:28 -0800 | [diff] [blame] | 115 | $(OUTPUT)/test_sock_fields: cgroup_helpers.c |
Jesper Dangaard Brouer | 41757dc | 2018-02-13 14:19:15 +0100 | [diff] [blame] | 116 | |
Zi Shen Lim | e8f1f34 | 2017-03-19 23:03:14 -0700 | [diff] [blame] | 117 | .PHONY: force |
Mickaël Salaün | d498f87 | 2017-02-11 23:20:23 +0100 | [diff] [blame] | 118 | |
Mickaël Salaün | d498f87 | 2017-02-11 23:20:23 +0100 | [diff] [blame] | 119 | # force a rebuild of BPFOBJ when its dependencies are updated |
| 120 | force: |
| 121 | |
| 122 | $(BPFOBJ): force |
Zi Shen Lim | e8f1f34 | 2017-03-19 23:03:14 -0700 | [diff] [blame] | 123 | $(MAKE) -C $(BPFDIR) OUTPUT=$(OUTPUT)/ |
Alexei Starovoitov | 6882804 | 2017-03-30 21:45:41 -0700 | [diff] [blame] | 124 | |
Quentin Monnet | cd95a89 | 2017-12-21 08:52:50 -0800 | [diff] [blame] | 125 | PROBE := $(shell $(LLC) -march=bpf -mcpu=probe -filetype=null /dev/null 2>&1) |
Daniel Borkmann | 22c8852 | 2017-09-25 02:25:53 +0200 | [diff] [blame] | 126 | |
| 127 | # Let newer LLVM versions transparently probe the kernel for availability |
| 128 | # of full BPF instruction set. |
| 129 | ifeq ($(PROBE),) |
| 130 | CPU ?= probe |
| 131 | else |
| 132 | CPU ?= generic |
| 133 | endif |
Alexei Starovoitov | 6882804 | 2017-03-30 21:45:41 -0700 | [diff] [blame] | 134 | |
Sirio Balmelli | 167381f | 2018-05-21 09:00:03 +0200 | [diff] [blame] | 135 | # Get Clang's default includes on this system, as opposed to those seen by |
| 136 | # '-target bpf'. This fixes "missing" files on some architectures/distros, |
| 137 | # such as asm/byteorder.h, asm/socket.h, asm/sockios.h, sys/cdefs.h etc. |
| 138 | # |
| 139 | # Use '-idirafter': Don't interfere with include mechanics except where the |
| 140 | # build would have failed anyways. |
| 141 | CLANG_SYS_INCLUDES := $(shell $(CLANG) -v -E - </dev/null 2>&1 \ |
| 142 | | sed -n '/<...> search starts here:/,/End of search list./{ s| \(/.*\)|-idirafter \1|p }') |
| 143 | |
Alexei Starovoitov | 3bc35c6 | 2017-12-14 17:55:11 -0800 | [diff] [blame] | 144 | CLANG_FLAGS = -I. -I./include/uapi -I../../../include/uapi \ |
Sirio Balmelli | 167381f | 2018-05-21 09:00:03 +0200 | [diff] [blame] | 145 | $(CLANG_SYS_INCLUDES) \ |
Alexei Starovoitov | 3bc35c6 | 2017-12-14 17:55:11 -0800 | [diff] [blame] | 146 | -Wno-compare-distinct-pointer-types |
| 147 | |
| 148 | $(OUTPUT)/test_l4lb_noinline.o: CLANG_FLAGS += -fno-inline |
Alexei Starovoitov | b0b04fc | 2017-12-14 17:55:12 -0800 | [diff] [blame] | 149 | $(OUTPUT)/test_xdp_noinline.o: CLANG_FLAGS += -fno-inline |
Alexei Starovoitov | 3bc35c6 | 2017-12-14 17:55:11 -0800 | [diff] [blame] | 150 | |
Mauricio Vasquez B | 43b987d | 2018-10-18 15:16:41 +0200 | [diff] [blame] | 151 | $(OUTPUT)/test_queue_map.o: test_queue_stack_map.h |
| 152 | $(OUTPUT)/test_stack_map.o: test_queue_stack_map.h |
| 153 | |
Stanislav Fomichev | bf0f0fd | 2019-01-28 08:53:55 -0800 | [diff] [blame] | 154 | $(OUTPUT)/flow_dissector_load.o: flow_dissector_load.h |
| 155 | $(OUTPUT)/test_progs.o: flow_dissector_load.h |
| 156 | |
Joe Stringer | 91bc07c | 2018-05-10 15:26:51 -0700 | [diff] [blame] | 157 | BTF_LLC_PROBE := $(shell $(LLC) -march=bpf -mattr=help 2>&1 | grep dwarfris) |
| 158 | BTF_PAHOLE_PROBE := $(shell $(BTF_PAHOLE) --help 2>&1 | grep BTF) |
Martin KaFai Lau | 7c3e8b6 | 2018-07-19 22:34:10 -0700 | [diff] [blame] | 159 | BTF_OBJCOPY_PROBE := $(shell $(LLVM_OBJCOPY) --help 2>&1 | grep -i 'usage.*llvm') |
Yonghong Song | 9ce6ae2 | 2018-11-19 15:29:17 -0800 | [diff] [blame] | 160 | BTF_LLVM_PROBE := $(shell echo "int main() { return 0; }" | \ |
| 161 | $(CLANG) -target bpf -O2 -g -c -x c - -o ./llvm_btf_verify.o; \ |
Stanislav Fomichev | 2f09212 | 2019-01-24 08:54:29 -0800 | [diff] [blame] | 162 | $(LLVM_READELF) -S ./llvm_btf_verify.o | grep BTF; \ |
Yonghong Song | 9ce6ae2 | 2018-11-19 15:29:17 -0800 | [diff] [blame] | 163 | /bin/rm -f ./llvm_btf_verify.o) |
Martin KaFai Lau | c0fa1b6 | 2018-04-18 15:56:06 -0700 | [diff] [blame] | 164 | |
Yonghong Song | 9ce6ae2 | 2018-11-19 15:29:17 -0800 | [diff] [blame] | 165 | ifneq ($(BTF_LLVM_PROBE),) |
| 166 | CLANG_FLAGS += -g |
| 167 | else |
Martin KaFai Lau | c0fa1b6 | 2018-04-18 15:56:06 -0700 | [diff] [blame] | 168 | ifneq ($(BTF_LLC_PROBE),) |
| 169 | ifneq ($(BTF_PAHOLE_PROBE),) |
| 170 | ifneq ($(BTF_OBJCOPY_PROBE),) |
| 171 | CLANG_FLAGS += -g |
| 172 | LLC_FLAGS += -mattr=dwarfris |
| 173 | DWARF2BTF = y |
| 174 | endif |
| 175 | endif |
| 176 | endif |
Yonghong Song | 9ce6ae2 | 2018-11-19 15:29:17 -0800 | [diff] [blame] | 177 | endif |
Martin KaFai Lau | c0fa1b6 | 2018-04-18 15:56:06 -0700 | [diff] [blame] | 178 | |
Jiong Wang | 3ef8434 | 2019-01-26 12:26:14 -0500 | [diff] [blame] | 179 | ifneq ($(SUBREG_CODEGEN),) |
| 180 | ALU32_BUILD_DIR = $(OUTPUT)/alu32 |
| 181 | TEST_CUSTOM_PROGS += $(ALU32_BUILD_DIR)/test_progs_32 |
| 182 | $(ALU32_BUILD_DIR): |
| 183 | mkdir -p $@ |
| 184 | |
| 185 | $(ALU32_BUILD_DIR)/urandom_read: $(OUTPUT)/urandom_read |
| 186 | cp $< $@ |
| 187 | |
| 188 | $(ALU32_BUILD_DIR)/test_progs_32: test_progs.c $(ALU32_BUILD_DIR) \ |
| 189 | $(ALU32_BUILD_DIR)/urandom_read |
| 190 | $(CC) $(CFLAGS) -o $(ALU32_BUILD_DIR)/test_progs_32 $< \ |
| 191 | trace_helpers.c $(OUTPUT)/libbpf.a $(LDLIBS) |
| 192 | |
| 193 | $(ALU32_BUILD_DIR)/%.o: %.c $(ALU32_BUILD_DIR) $(ALU32_BUILD_DIR)/test_progs_32 |
| 194 | $(CLANG) $(CLANG_FLAGS) \ |
| 195 | -O2 -target bpf -emit-llvm -c $< -o - | \ |
| 196 | $(LLC) -march=bpf -mattr=+alu32 -mcpu=$(CPU) $(LLC_FLAGS) \ |
| 197 | -filetype=obj -o $@ |
| 198 | ifeq ($(DWARF2BTF),y) |
| 199 | $(BTF_PAHOLE) -J $@ |
| 200 | endif |
| 201 | endif |
| 202 | |
Quentin Monnet | f96afa7 | 2018-11-07 12:28:45 +0000 | [diff] [blame] | 203 | # Have one program compiled without "-target bpf" to test whether libbpf loads |
| 204 | # it successfully |
| 205 | $(OUTPUT)/test_xdp.o: test_xdp.c |
| 206 | $(CLANG) $(CLANG_FLAGS) \ |
| 207 | -O2 -emit-llvm -c $< -o - | \ |
| 208 | $(LLC) -march=bpf -mcpu=$(CPU) $(LLC_FLAGS) -filetype=obj -o $@ |
| 209 | ifeq ($(DWARF2BTF),y) |
| 210 | $(BTF_PAHOLE) -J $@ |
| 211 | endif |
Alexei Starovoitov | 6882804 | 2017-03-30 21:45:41 -0700 | [diff] [blame] | 212 | |
Yonghong Song | 62a0699 | 2018-01-29 21:23:28 -0800 | [diff] [blame] | 213 | $(OUTPUT)/%.o: %.c |
Alexei Starovoitov | 3bc35c6 | 2017-12-14 17:55:11 -0800 | [diff] [blame] | 214 | $(CLANG) $(CLANG_FLAGS) \ |
Daniel Borkmann | 22c8852 | 2017-09-25 02:25:53 +0200 | [diff] [blame] | 215 | -O2 -target bpf -emit-llvm -c $< -o - | \ |
Martin KaFai Lau | c0fa1b6 | 2018-04-18 15:56:06 -0700 | [diff] [blame] | 216 | $(LLC) -march=bpf -mcpu=$(CPU) $(LLC_FLAGS) -filetype=obj -o $@ |
| 217 | ifeq ($(DWARF2BTF),y) |
| 218 | $(BTF_PAHOLE) -J $@ |
| 219 | endif |
Song Liu | 81f77fd | 2018-03-14 10:23:22 -0700 | [diff] [blame] | 220 | |
Stanislav Fomichev | 2a11815 | 2019-02-01 15:46:38 -0800 | [diff] [blame] | 221 | VERIFIER_TESTS_H := $(OUTPUT)/verifier/tests.h |
| 222 | $(OUTPUT)/test_verifier: $(VERIFIER_TESTS_H) |
Jakub Kicinski | 2dfb401 | 2019-01-25 15:24:42 -0800 | [diff] [blame] | 223 | $(OUTPUT)/test_verifier: CFLAGS += -I$(OUTPUT) |
| 224 | |
| 225 | VERIFIER_TEST_FILES := $(wildcard verifier/*.c) |
| 226 | $(OUTPUT)/verifier/tests.h: $(VERIFIER_TEST_FILES) |
| 227 | $(shell ( cd verifier/ |
| 228 | echo '/* Generated header, do not edit */'; \ |
| 229 | echo '#ifdef FILL_ARRAY'; \ |
| 230 | ls *.c 2> /dev/null | \ |
| 231 | sed -e 's@\(.*\)@#include \"\1\"@'; \ |
| 232 | echo '#endif' \ |
Stanislav Fomichev | 2a11815 | 2019-02-01 15:46:38 -0800 | [diff] [blame] | 233 | ) > $(VERIFIER_TESTS_H)) |
Jakub Kicinski | 2dfb401 | 2019-01-25 15:24:42 -0800 | [diff] [blame] | 234 | |
Stanislav Fomichev | 2a11815 | 2019-02-01 15:46:38 -0800 | [diff] [blame] | 235 | EXTRA_CLEAN := $(TEST_CUSTOM_PROGS) $(ALU32_BUILD_DIR) \ |
| 236 | $(VERIFIER_TESTS_H) |