Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | # SPDX-License-Identifier: GPL-2.0 |
Jakub Kicinski | 787360f | 2018-05-14 22:35:04 -0700 | [diff] [blame] | 2 | |
| 3 | BPF_SAMPLES_PATH ?= $(abspath $(srctree)/$(src)) |
| 4 | TOOLS_PATH := $(BPF_SAMPLES_PATH)/../../tools |
| 5 | |
Alexei Starovoitov | 3c731eb | 2014-09-26 00:17:07 -0700 | [diff] [blame] | 6 | # List of programs to build |
Ivan Khoronzhuk | 1d97c6c | 2019-10-11 03:28:01 +0300 | [diff] [blame] | 7 | tprogs-y := test_lru_dist |
| 8 | tprogs-y += sock_example |
| 9 | tprogs-y += fds_example |
| 10 | tprogs-y += sockex1 |
| 11 | tprogs-y += sockex2 |
| 12 | tprogs-y += sockex3 |
| 13 | tprogs-y += tracex1 |
| 14 | tprogs-y += tracex2 |
| 15 | tprogs-y += tracex3 |
| 16 | tprogs-y += tracex4 |
| 17 | tprogs-y += tracex5 |
| 18 | tprogs-y += tracex6 |
| 19 | tprogs-y += tracex7 |
| 20 | tprogs-y += test_probe_write_user |
| 21 | tprogs-y += trace_output |
| 22 | tprogs-y += lathist |
| 23 | tprogs-y += offwaketime |
| 24 | tprogs-y += spintest |
| 25 | tprogs-y += map_perf_test |
| 26 | tprogs-y += test_overhead |
| 27 | tprogs-y += test_cgrp2_array_pin |
| 28 | tprogs-y += test_cgrp2_attach |
| 29 | tprogs-y += test_cgrp2_sock |
| 30 | tprogs-y += test_cgrp2_sock2 |
| 31 | tprogs-y += xdp1 |
| 32 | tprogs-y += xdp2 |
| 33 | tprogs-y += xdp_router_ipv4 |
| 34 | tprogs-y += test_current_task_under_cgroup |
| 35 | tprogs-y += trace_event |
| 36 | tprogs-y += sampleip |
| 37 | tprogs-y += tc_l2_redirect |
| 38 | tprogs-y += lwt_len_hist |
| 39 | tprogs-y += xdp_tx_iptunnel |
| 40 | tprogs-y += test_map_in_map |
| 41 | tprogs-y += xdp_redirect_map |
| 42 | tprogs-y += xdp_redirect_cpu |
| 43 | tprogs-y += xdp_monitor |
| 44 | tprogs-y += xdp_rxq_info |
| 45 | tprogs-y += syscall_tp |
| 46 | tprogs-y += cpustat |
| 47 | tprogs-y += xdp_adjust_tail |
| 48 | tprogs-y += xdpsock |
| 49 | tprogs-y += xdp_fwd |
| 50 | tprogs-y += task_fd_query |
| 51 | tprogs-y += xdp_sample_pkts |
| 52 | tprogs-y += ibumad |
| 53 | tprogs-y += hbm |
Alexei Starovoitov | 3c731eb | 2014-09-26 00:17:07 -0700 | [diff] [blame] | 54 | |
Joe Stringer | 43371c8 | 2016-12-14 14:43:39 -0800 | [diff] [blame] | 55 | # Libbpf dependencies |
Jakub Kicinski | 787360f | 2018-05-14 22:35:04 -0700 | [diff] [blame] | 56 | LIBBPF = $(TOOLS_PATH)/lib/bpf/libbpf.a |
| 57 | |
Roman Gushchin | 9d1f159 | 2017-11-05 08:15:33 -0500 | [diff] [blame] | 58 | CGROUP_HELPERS := ../../tools/testing/selftests/bpf/cgroup_helpers.o |
Yonghong Song | 28dbf86 | 2018-04-28 22:28:13 -0700 | [diff] [blame] | 59 | TRACE_HELPERS := ../../tools/testing/selftests/bpf/trace_helpers.o |
Joe Stringer | 43371c8 | 2016-12-14 14:43:39 -0800 | [diff] [blame] | 60 | |
Jakub Kicinski | 1a9b268 | 2019-02-27 19:04:13 -0800 | [diff] [blame] | 61 | fds_example-objs := fds_example.o |
| 62 | sockex1-objs := sockex1_user.o |
| 63 | sockex2-objs := sockex2_user.o |
Jakub Kicinski | 0cc54db | 2018-05-14 22:35:05 -0700 | [diff] [blame] | 64 | sockex3-objs := bpf_load.o sockex3_user.o |
| 65 | tracex1-objs := bpf_load.o tracex1_user.o |
| 66 | tracex2-objs := bpf_load.o tracex2_user.o |
| 67 | tracex3-objs := bpf_load.o tracex3_user.o |
| 68 | tracex4-objs := bpf_load.o tracex4_user.o |
| 69 | tracex5-objs := bpf_load.o tracex5_user.o |
| 70 | tracex6-objs := bpf_load.o tracex6_user.o |
| 71 | tracex7-objs := bpf_load.o tracex7_user.o |
Jakub Kicinski | 0cc54db | 2018-05-14 22:35:05 -0700 | [diff] [blame] | 72 | test_probe_write_user-objs := bpf_load.o test_probe_write_user_user.o |
| 73 | trace_output-objs := bpf_load.o trace_output_user.o $(TRACE_HELPERS) |
| 74 | lathist-objs := bpf_load.o lathist_user.o |
| 75 | offwaketime-objs := bpf_load.o offwaketime_user.o $(TRACE_HELPERS) |
| 76 | spintest-objs := bpf_load.o spintest_user.o $(TRACE_HELPERS) |
| 77 | map_perf_test-objs := bpf_load.o map_perf_test_user.o |
| 78 | test_overhead-objs := bpf_load.o test_overhead_user.o |
| 79 | test_cgrp2_array_pin-objs := test_cgrp2_array_pin.o |
| 80 | test_cgrp2_attach-objs := test_cgrp2_attach.o |
Jakub Kicinski | 0cc54db | 2018-05-14 22:35:05 -0700 | [diff] [blame] | 81 | test_cgrp2_sock-objs := test_cgrp2_sock.o |
| 82 | test_cgrp2_sock2-objs := bpf_load.o test_cgrp2_sock2.o |
| 83 | xdp1-objs := xdp1_user.o |
Brenden Blanco | 764cbcce | 2016-07-19 12:16:57 -0700 | [diff] [blame] | 84 | # reuse xdp1 source intentionally |
Jakub Kicinski | 0cc54db | 2018-05-14 22:35:05 -0700 | [diff] [blame] | 85 | xdp2-objs := xdp1_user.o |
Maciej Fijalkowski | bbaf602 | 2019-02-01 22:42:25 +0100 | [diff] [blame] | 86 | xdp_router_ipv4-objs := xdp_router_ipv4_user.o |
Jakub Kicinski | 0cc54db | 2018-05-14 22:35:05 -0700 | [diff] [blame] | 87 | test_current_task_under_cgroup-objs := bpf_load.o $(CGROUP_HELPERS) \ |
Sargun Dhillon | 9e6e60e | 2016-08-12 08:57:04 -0700 | [diff] [blame] | 88 | test_current_task_under_cgroup_user.o |
Jakub Kicinski | 0cc54db | 2018-05-14 22:35:05 -0700 | [diff] [blame] | 89 | trace_event-objs := bpf_load.o trace_event_user.o $(TRACE_HELPERS) |
| 90 | sampleip-objs := bpf_load.o sampleip_user.o $(TRACE_HELPERS) |
| 91 | tc_l2_redirect-objs := bpf_load.o tc_l2_redirect_user.o |
| 92 | lwt_len_hist-objs := bpf_load.o lwt_len_hist_user.o |
Maciej Fijalkowski | bbaf602 | 2019-02-01 22:42:25 +0100 | [diff] [blame] | 93 | xdp_tx_iptunnel-objs := xdp_tx_iptunnel_user.o |
Jakub Kicinski | 0cc54db | 2018-05-14 22:35:05 -0700 | [diff] [blame] | 94 | test_map_in_map-objs := bpf_load.o test_map_in_map_user.o |
| 95 | per_socket_stats_example-objs := cookie_uid_helper_example.o |
Maciej Fijalkowski | bbaf602 | 2019-02-01 22:42:25 +0100 | [diff] [blame] | 96 | xdp_redirect-objs := xdp_redirect_user.o |
| 97 | xdp_redirect_map-objs := xdp_redirect_map_user.o |
Jakub Kicinski | 0cc54db | 2018-05-14 22:35:05 -0700 | [diff] [blame] | 98 | xdp_redirect_cpu-objs := bpf_load.o xdp_redirect_cpu_user.o |
| 99 | xdp_monitor-objs := bpf_load.o xdp_monitor_user.o |
| 100 | xdp_rxq_info-objs := xdp_rxq_info_user.o |
| 101 | syscall_tp-objs := bpf_load.o syscall_tp_user.o |
| 102 | cpustat-objs := bpf_load.o cpustat_user.o |
| 103 | xdp_adjust_tail-objs := xdp_adjust_tail_user.o |
Jakub Kicinski | 6748182 | 2018-07-26 14:32:21 -0700 | [diff] [blame] | 104 | xdpsock-objs := xdpsock_user.o |
Jakub Kicinski | e1a40ef | 2018-07-26 14:32:20 -0700 | [diff] [blame] | 105 | xdp_fwd-objs := xdp_fwd_user.o |
Yonghong Song | ecb96f7 | 2018-05-24 11:21:56 -0700 | [diff] [blame] | 106 | task_fd_query-objs := bpf_load.o task_fd_query_user.o $(TRACE_HELPERS) |
Toke Høiland-Jørgensen | 1e54ad2 | 2018-06-25 14:25:02 +0200 | [diff] [blame] | 107 | xdp_sample_pkts-objs := xdp_sample_pkts_user.o $(TRACE_HELPERS) |
Ira Weiny | 0ac01fe | 2019-03-19 14:11:49 -0700 | [diff] [blame] | 108 | ibumad-objs := bpf_load.o ibumad_user.o $(TRACE_HELPERS) |
brakmo | a1270fe | 2019-03-01 12:38:49 -0800 | [diff] [blame] | 109 | hbm-objs := bpf_load.o hbm.o $(CGROUP_HELPERS) |
Alexei Starovoitov | 3c731eb | 2014-09-26 00:17:07 -0700 | [diff] [blame] | 110 | |
| 111 | # Tell kbuild to always build the programs |
Ivan Khoronzhuk | 1d97c6c | 2019-10-11 03:28:01 +0300 | [diff] [blame] | 112 | always := $(tprogs-y) |
Alexei Starovoitov | a808578 | 2014-12-01 15:06:38 -0800 | [diff] [blame] | 113 | always += sockex1_kern.o |
Alexei Starovoitov | fbe3310 | 2014-12-01 15:06:39 -0800 | [diff] [blame] | 114 | always += sockex2_kern.o |
Alexei Starovoitov | 530b2c8 | 2015-05-19 16:59:06 -0700 | [diff] [blame] | 115 | always += sockex3_kern.o |
Alexei Starovoitov | b896c4f | 2015-03-25 12:49:23 -0700 | [diff] [blame] | 116 | always += tracex1_kern.o |
Alexei Starovoitov | d822a19 | 2015-03-25 12:49:24 -0700 | [diff] [blame] | 117 | always += tracex2_kern.o |
Alexei Starovoitov | 5c7fc2d | 2015-03-25 12:49:25 -0700 | [diff] [blame] | 118 | always += tracex3_kern.o |
Alexei Starovoitov | 9811e35 | 2015-03-25 12:49:26 -0700 | [diff] [blame] | 119 | always += tracex4_kern.o |
Alexei Starovoitov | 5bacd78 | 2015-05-19 16:59:05 -0700 | [diff] [blame] | 120 | always += tracex5_kern.o |
Kaixu Xia | 47efb30 | 2015-08-06 07:02:36 +0000 | [diff] [blame] | 121 | always += tracex6_kern.o |
Josef Bacik | 965de87 | 2017-12-11 11:36:49 -0500 | [diff] [blame] | 122 | always += tracex7_kern.o |
David Ahern | 554ae6e | 2016-12-01 08:48:08 -0800 | [diff] [blame] | 123 | always += sock_flags_kern.o |
Sargun Dhillon | cf9b119 | 2016-07-25 05:55:02 -0700 | [diff] [blame] | 124 | always += test_probe_write_user_kern.o |
Alexei Starovoitov | 3911169 | 2015-10-20 20:02:35 -0700 | [diff] [blame] | 125 | always += trace_output_kern.o |
Alexei Starovoitov | 91bc4822 | 2015-04-01 17:12:13 -0700 | [diff] [blame] | 126 | always += tcbpf1_kern.o |
Martin KaFai Lau | 90e0289 | 2016-11-09 15:36:34 -0800 | [diff] [blame] | 127 | always += tc_l2_redirect_kern.o |
Daniel Wagner | 0fb1170 | 2015-06-19 16:00:44 +0200 | [diff] [blame] | 128 | always += lathist_kern.o |
Alexei Starovoitov | a6ffe7b | 2016-02-17 19:58:59 -0800 | [diff] [blame] | 129 | always += offwaketime_kern.o |
Alexei Starovoitov | 9d8b612 | 2016-03-08 15:07:52 -0800 | [diff] [blame] | 130 | always += spintest_kern.o |
Alexei Starovoitov | 26e9093 | 2016-03-08 15:07:54 -0800 | [diff] [blame] | 131 | always += map_perf_test_kern.o |
Alexei Starovoitov | e3edfde | 2016-04-06 18:43:31 -0700 | [diff] [blame] | 132 | always += test_overhead_tp_kern.o |
Alexei Starovoitov | 4662a4e | 2018-03-28 12:05:39 -0700 | [diff] [blame] | 133 | always += test_overhead_raw_tp_kern.o |
Alexei Starovoitov | e3edfde | 2016-04-06 18:43:31 -0700 | [diff] [blame] | 134 | always += test_overhead_kprobe_kern.o |
Alexei Starovoitov | 65d472f | 2016-05-05 19:49:14 -0700 | [diff] [blame] | 135 | always += parse_varlen.o parse_simple.o parse_ldabs.o |
Martin KaFai Lau | a3f7461 | 2016-06-30 10:28:45 -0700 | [diff] [blame] | 136 | always += test_cgrp2_tc_kern.o |
Brenden Blanco | 86af8b4 | 2016-07-19 12:16:51 -0700 | [diff] [blame] | 137 | always += xdp1_kern.o |
Brenden Blanco | 764cbcce | 2016-07-19 12:16:57 -0700 | [diff] [blame] | 138 | always += xdp2_kern.o |
Christina Jacob | 3e29cd0 | 2017-11-05 08:52:30 +0530 | [diff] [blame] | 139 | always += xdp_router_ipv4_kern.o |
Sargun Dhillon | 9e6e60e | 2016-08-12 08:57:04 -0700 | [diff] [blame] | 140 | always += test_current_task_under_cgroup_kern.o |
Alexei Starovoitov | 1c47910e | 2016-09-01 18:37:25 -0700 | [diff] [blame] | 141 | always += trace_event_kern.o |
Brendan Gregg | 7287441 | 2016-09-01 18:37:26 -0700 | [diff] [blame] | 142 | always += sampleip_kern.o |
Thomas Graf | f74599f | 2016-11-30 17:10:11 +0100 | [diff] [blame] | 143 | always += lwt_len_hist_kern.o |
Martin KaFai Lau | 12d8bb6 | 2016-12-07 15:53:14 -0800 | [diff] [blame] | 144 | always += xdp_tx_iptunnel_kern.o |
Martin KaFai Lau | fb30d4b | 2017-03-22 10:00:35 -0700 | [diff] [blame] | 145 | always += test_map_in_map_kern.o |
Lawrence Brakmo | 61bc4d8 | 2017-06-30 20:02:43 -0700 | [diff] [blame] | 146 | always += tcp_synrto_kern.o |
Lawrence Brakmo | c400296 | 2017-06-30 20:02:45 -0700 | [diff] [blame] | 147 | always += tcp_rwnd_kern.o |
Lawrence Brakmo | d9925368 | 2017-06-30 20:02:48 -0700 | [diff] [blame] | 148 | always += tcp_bufs_kern.o |
Lawrence Brakmo | bb56d44 | 2017-06-30 20:02:50 -0700 | [diff] [blame] | 149 | always += tcp_cong_kern.o |
Lawrence Brakmo | 7bc62e2 | 2017-06-30 20:02:52 -0700 | [diff] [blame] | 150 | always += tcp_iw_kern.o |
Lawrence Brakmo | 6c4a01b | 2017-06-30 20:02:54 -0700 | [diff] [blame] | 151 | always += tcp_clamp_kern.o |
Lawrence Brakmo | c890063 | 2017-10-20 11:05:42 -0700 | [diff] [blame] | 152 | always += tcp_basertt_kern.o |
Nikita V. Shirokov | acb4ea9 | 2018-08-30 07:51:54 -0700 | [diff] [blame] | 153 | always += tcp_tos_reflect_kern.o |
Stanislav Fomichev | 3953388 | 2019-07-02 09:14:02 -0700 | [diff] [blame] | 154 | always += tcp_dumpstats_kern.o |
John Fastabend | 832622e | 2017-07-17 09:27:28 -0700 | [diff] [blame] | 155 | always += xdp_redirect_kern.o |
John Fastabend | 9d6e005 | 2017-07-17 09:30:25 -0700 | [diff] [blame] | 156 | always += xdp_redirect_map_kern.o |
Jesper Dangaard Brouer | fad3917 | 2017-10-16 12:19:49 +0200 | [diff] [blame] | 157 | always += xdp_redirect_cpu_kern.o |
Jesper Dangaard Brouer | 3ffab54 | 2017-08-29 16:38:11 +0200 | [diff] [blame] | 158 | always += xdp_monitor_kern.o |
Jesper Dangaard Brouer | 0fca931 | 2018-01-03 11:26:19 +0100 | [diff] [blame] | 159 | always += xdp_rxq_info_kern.o |
Jesper Dangaard Brouer | 36e04a2 | 2018-01-10 18:21:44 +0100 | [diff] [blame] | 160 | always += xdp2skb_meta_kern.o |
Yonghong Song | 1da236b6b | 2017-08-04 16:00:10 -0700 | [diff] [blame] | 161 | always += syscall_tp_kern.o |
Leo Yan | c535077 | 2018-02-26 09:19:12 +0800 | [diff] [blame] | 162 | always += cpustat_kern.o |
Nikita V. Shirokov | c6ffd1f | 2018-04-17 21:42:23 -0700 | [diff] [blame] | 163 | always += xdp_adjust_tail_kern.o |
David Ahern | fe61605 | 2018-05-09 20:34:27 -0700 | [diff] [blame] | 164 | always += xdp_fwd_kern.o |
Yonghong Song | ecb96f7 | 2018-05-24 11:21:56 -0700 | [diff] [blame] | 165 | always += task_fd_query_kern.o |
Toke Høiland-Jørgensen | 1e54ad2 | 2018-06-25 14:25:02 +0200 | [diff] [blame] | 166 | always += xdp_sample_pkts_kern.o |
Ira Weiny | 0ac01fe | 2019-03-19 14:11:49 -0700 | [diff] [blame] | 167 | always += ibumad_kern.o |
brakmo | 187d073 | 2019-03-01 12:38:48 -0800 | [diff] [blame] | 168 | always += hbm_out_kern.o |
brakmo | 71634d7 | 2019-07-02 15:09:52 -0700 | [diff] [blame] | 169 | always += hbm_edt_kern.o |
Alexei Starovoitov | 3c731eb | 2014-09-26 00:17:07 -0700 | [diff] [blame] | 170 | |
Ivan Khoronzhuk | 0e865ae | 2019-10-11 03:27:58 +0300 | [diff] [blame] | 171 | ifeq ($(ARCH), arm) |
| 172 | # Strip all except -D__LINUX_ARM_ARCH__ option needed to handle linux |
| 173 | # headers when arm instruction set identification is requested. |
| 174 | ARM_ARCH_SELECTOR := $(filter -D__LINUX_ARM_ARCH__%, $(KBUILD_CFLAGS)) |
| 175 | BPF_EXTRA_CFLAGS := $(ARM_ARCH_SELECTOR) |
Ivan Khoronzhuk | 1d97c6c | 2019-10-11 03:28:01 +0300 | [diff] [blame] | 176 | TPROGS_CFLAGS += $(ARM_ARCH_SELECTOR) |
Ivan Khoronzhuk | 0e865ae | 2019-10-11 03:27:58 +0300 | [diff] [blame] | 177 | endif |
| 178 | |
Ivan Khoronzhuk | 10cb3d8 | 2019-10-11 03:28:02 +0300 | [diff] [blame] | 179 | TPROGS_CFLAGS += -Wall -O2 |
| 180 | TPROGS_CFLAGS += -Wmissing-prototypes |
| 181 | TPROGS_CFLAGS += -Wstrict-prototypes |
| 182 | |
Ivan Khoronzhuk | 1d97c6c | 2019-10-11 03:28:01 +0300 | [diff] [blame] | 183 | TPROGS_CFLAGS += -I$(objtree)/usr/include |
| 184 | TPROGS_CFLAGS += -I$(srctree)/tools/lib/bpf/ |
| 185 | TPROGS_CFLAGS += -I$(srctree)/tools/testing/selftests/bpf/ |
| 186 | TPROGS_CFLAGS += -I$(srctree)/tools/lib/ |
| 187 | TPROGS_CFLAGS += -I$(srctree)/tools/include |
| 188 | TPROGS_CFLAGS += -I$(srctree)/tools/perf |
David S. Miller | 14684b9 | 2019-11-09 11:04:37 -0800 | [diff] [blame] | 189 | TPROGS_CFLAGS += -DHAVE_ATTR_TEST=0 |
Ivan Khoronzhuk | 1d97c6c | 2019-10-11 03:28:01 +0300 | [diff] [blame] | 190 | |
Ivan Khoronzhuk | b2327c1 | 2019-10-11 03:28:07 +0300 | [diff] [blame] | 191 | ifdef SYSROOT |
| 192 | TPROGS_CFLAGS += --sysroot=$(SYSROOT) |
| 193 | TPROGS_LDFLAGS := -L$(SYSROOT)/usr/lib |
| 194 | endif |
| 195 | |
Ivan Khoronzhuk | 1d97c6c | 2019-10-11 03:28:01 +0300 | [diff] [blame] | 196 | TPROGCFLAGS_bpf_load.o += -Wno-unused-variable |
| 197 | |
| 198 | TPROGS_LDLIBS += $(LIBBPF) -lelf |
| 199 | TPROGLDLIBS_tracex4 += -lrt |
| 200 | TPROGLDLIBS_trace_output += -lrt |
| 201 | TPROGLDLIBS_map_perf_test += -lrt |
| 202 | TPROGLDLIBS_test_overhead += -lrt |
| 203 | TPROGLDLIBS_xdpsock += -pthread |
| 204 | |
Jesper Dangaard Brouer | bdefbbf | 2016-04-28 14:21:14 +0200 | [diff] [blame] | 205 | # Allows pointing LLC/CLANG to a LLVM backend with bpf support, redefine on cmdline: |
| 206 | # make samples/bpf/ LLC=~/git/llvm/build/bin/llc CLANG=~/git/llvm/build/bin/clang |
Jesper Dangaard Brouer | 6ccfba7 | 2016-04-28 14:20:53 +0200 | [diff] [blame] | 207 | LLC ?= llc |
Jesper Dangaard Brouer | bdefbbf | 2016-04-28 14:21:14 +0200 | [diff] [blame] | 208 | CLANG ?= clang |
Taeung Song | 9778cfd | 2018-07-26 19:13:44 +0900 | [diff] [blame] | 209 | LLVM_OBJCOPY ?= llvm-objcopy |
| 210 | BTF_PAHOLE ?= pahole |
Jesper Dangaard Brouer | 6ccfba7 | 2016-04-28 14:20:53 +0200 | [diff] [blame] | 211 | |
Joel Fernandes | 876e88e | 2017-09-20 09:11:57 -0700 | [diff] [blame] | 212 | # Detect that we're cross compiling and use the cross compiler |
| 213 | ifdef CROSS_COMPILE |
Ivan Khoronzhuk | 518c134 | 2019-10-11 03:27:56 +0300 | [diff] [blame] | 214 | CLANG_ARCH_ARGS = --target=$(notdir $(CROSS_COMPILE:%-=%)) |
Joel Fernandes | 876e88e | 2017-09-20 09:11:57 -0700 | [diff] [blame] | 215 | endif |
| 216 | |
Jakub Kicinski | 0ed3cc4 | 2019-06-07 10:11:16 -0700 | [diff] [blame] | 217 | # Don't evaluate probes and warnings if we need to run make recursively |
| 218 | ifneq ($(src),) |
Ivan Khoronzhuk | cdd5b2d | 2019-10-11 03:27:54 +0300 | [diff] [blame] | 219 | HDR_PROBE := $(shell printf "\#include <linux/types.h>\n struct list_head { int a; }; int main() { return 0; }" | \ |
Ivan Khoronzhuk | a833eff | 2019-10-11 03:28:03 +0300 | [diff] [blame] | 220 | $(CC) $(TPROGS_CFLAGS) $(TPROGS_LDFLAGS) -x c - \ |
| 221 | -o /dev/null 2>/dev/null && echo okay) |
Jakub Kicinski | 07c3bbd | 2019-06-05 16:47:22 -0700 | [diff] [blame] | 222 | |
| 223 | ifeq ($(HDR_PROBE),) |
| 224 | $(warning WARNING: Detected possible issues with include path.) |
| 225 | $(warning WARNING: Please install kernel headers locally (make headers_install).) |
| 226 | endif |
| 227 | |
Taeung Song | 9778cfd | 2018-07-26 19:13:44 +0900 | [diff] [blame] | 228 | BTF_LLC_PROBE := $(shell $(LLC) -march=bpf -mattr=help 2>&1 | grep dwarfris) |
| 229 | BTF_PAHOLE_PROBE := $(shell $(BTF_PAHOLE) --help 2>&1 | grep BTF) |
| 230 | 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] | 231 | BTF_LLVM_PROBE := $(shell echo "int main() { return 0; }" | \ |
| 232 | $(CLANG) -target bpf -O2 -g -c -x c - -o ./llvm_btf_verify.o; \ |
| 233 | readelf -S ./llvm_btf_verify.o | grep BTF; \ |
| 234 | /bin/rm -f ./llvm_btf_verify.o) |
Taeung Song | 9778cfd | 2018-07-26 19:13:44 +0900 | [diff] [blame] | 235 | |
Yonghong Song | 9ce6ae2 | 2018-11-19 15:29:17 -0800 | [diff] [blame] | 236 | ifneq ($(BTF_LLVM_PROBE),) |
Ivan Khoronzhuk | 2a560df | 2019-10-11 03:27:57 +0300 | [diff] [blame] | 237 | BPF_EXTRA_CFLAGS += -g |
Yonghong Song | 9ce6ae2 | 2018-11-19 15:29:17 -0800 | [diff] [blame] | 238 | else |
Taeung Song | 9778cfd | 2018-07-26 19:13:44 +0900 | [diff] [blame] | 239 | ifneq ($(and $(BTF_LLC_PROBE),$(BTF_PAHOLE_PROBE),$(BTF_OBJCOPY_PROBE)),) |
Ivan Khoronzhuk | 2a560df | 2019-10-11 03:27:57 +0300 | [diff] [blame] | 240 | BPF_EXTRA_CFLAGS += -g |
Taeung Song | 9778cfd | 2018-07-26 19:13:44 +0900 | [diff] [blame] | 241 | LLC_FLAGS += -mattr=dwarfris |
| 242 | DWARF2BTF = y |
| 243 | endif |
Yonghong Song | 9ce6ae2 | 2018-11-19 15:29:17 -0800 | [diff] [blame] | 244 | endif |
Jakub Kicinski | 0ed3cc4 | 2019-06-07 10:11:16 -0700 | [diff] [blame] | 245 | endif |
Taeung Song | 9778cfd | 2018-07-26 19:13:44 +0900 | [diff] [blame] | 246 | |
Jesper Dangaard Brouer | b62a796 | 2016-04-28 14:21:09 +0200 | [diff] [blame] | 247 | # Trick to allow make to be run from this directory |
Jakub Kicinski | 787360f | 2018-05-14 22:35:04 -0700 | [diff] [blame] | 248 | all: |
| 249 | $(MAKE) -C ../../ $(CURDIR)/ BPF_SAMPLES_PATH=$(CURDIR) |
Jesper Dangaard Brouer | b62a796 | 2016-04-28 14:21:09 +0200 | [diff] [blame] | 250 | |
| 251 | clean: |
Uwe Kleine-König | e19b7ce | 2016-11-22 09:30:26 +0100 | [diff] [blame] | 252 | $(MAKE) -C ../../ M=$(CURDIR) clean |
Jesper Dangaard Brouer | b62a796 | 2016-04-28 14:21:09 +0200 | [diff] [blame] | 253 | @rm -f *~ |
| 254 | |
Mickaël Salaün | c25ef6a | 2018-01-26 01:39:30 +0100 | [diff] [blame] | 255 | $(LIBBPF): FORCE |
Jakub Kicinski | 787360f | 2018-05-14 22:35:04 -0700 | [diff] [blame] | 256 | # Fix up variables inherited from Kbuild that tools/ build system won't like |
Ivan Khoronzhuk | d8ceae9 | 2019-10-11 03:28:06 +0300 | [diff] [blame] | 257 | $(MAKE) -C $(dir $@) RM='rm -rf' EXTRA_CFLAGS="$(TPROGS_CFLAGS)" \ |
| 258 | LDFLAGS=$(TPROGS_LDFLAGS) srctree=$(BPF_SAMPLES_PATH)/../../ O= |
Mickaël Salaün | c25ef6a | 2018-01-26 01:39:30 +0100 | [diff] [blame] | 259 | |
David Daney | 4b7190e | 2017-06-13 16:49:38 -0700 | [diff] [blame] | 260 | $(obj)/syscall_nrs.h: $(obj)/syscall_nrs.s FORCE |
| 261 | $(call filechk,offsets,__SYSCALL_NRS_H__) |
| 262 | |
Masahiro Yamada | 2c667d7 | 2018-12-22 18:50:34 +0900 | [diff] [blame] | 263 | targets += syscall_nrs.s |
David Daney | 4b7190e | 2017-06-13 16:49:38 -0700 | [diff] [blame] | 264 | clean-files += syscall_nrs.h |
| 265 | |
| 266 | FORCE: |
| 267 | |
| 268 | |
Jesper Dangaard Brouer | bdefbbf | 2016-04-28 14:21:14 +0200 | [diff] [blame] | 269 | # Verify LLVM compiler tools are available and bpf target is supported by llc |
| 270 | .PHONY: verify_cmds verify_target_bpf $(CLANG) $(LLC) |
Jesper Dangaard Brouer | 7b01dd5 | 2016-04-28 14:20:58 +0200 | [diff] [blame] | 271 | |
Jesper Dangaard Brouer | bdefbbf | 2016-04-28 14:21:14 +0200 | [diff] [blame] | 272 | verify_cmds: $(CLANG) $(LLC) |
| 273 | @for TOOL in $^ ; do \ |
| 274 | if ! (which -- "$${TOOL}" > /dev/null 2>&1); then \ |
| 275 | echo "*** ERROR: Cannot find LLVM tool $${TOOL}" ;\ |
| 276 | exit 1; \ |
| 277 | else true; fi; \ |
| 278 | done |
Jesper Dangaard Brouer | 7b01dd5 | 2016-04-28 14:20:58 +0200 | [diff] [blame] | 279 | |
Jesper Dangaard Brouer | bdefbbf | 2016-04-28 14:21:14 +0200 | [diff] [blame] | 280 | verify_target_bpf: verify_cmds |
Jesper Dangaard Brouer | 7b01dd5 | 2016-04-28 14:20:58 +0200 | [diff] [blame] | 281 | @if ! (${LLC} -march=bpf -mattr=help > /dev/null 2>&1); then \ |
| 282 | echo "*** ERROR: LLVM (${LLC}) does not support 'bpf' target" ;\ |
| 283 | echo " NOTICE: LLVM version >= 3.7.1 required" ;\ |
| 284 | exit 2; \ |
| 285 | else true; fi |
| 286 | |
Jakub Kicinski | 787360f | 2018-05-14 22:35:04 -0700 | [diff] [blame] | 287 | $(BPF_SAMPLES_PATH)/*.c: verify_target_bpf $(LIBBPF) |
| 288 | $(src)/*.c: verify_target_bpf $(LIBBPF) |
Jesper Dangaard Brouer | 7b01dd5 | 2016-04-28 14:20:58 +0200 | [diff] [blame] | 289 | |
David Daney | 4b7190e | 2017-06-13 16:49:38 -0700 | [diff] [blame] | 290 | $(obj)/tracex5_kern.o: $(obj)/syscall_nrs.h |
brakmo | 187d073 | 2019-03-01 12:38:48 -0800 | [diff] [blame] | 291 | $(obj)/hbm_out_kern.o: $(src)/hbm.h $(src)/hbm_kern.h |
brakmo | a1270fe | 2019-03-01 12:38:49 -0800 | [diff] [blame] | 292 | $(obj)/hbm.o: $(src)/hbm.h |
brakmo | 71634d7 | 2019-07-02 15:09:52 -0700 | [diff] [blame] | 293 | $(obj)/hbm_edt_kern.o: $(src)/hbm.h $(src)/hbm_kern.h |
David Daney | 4b7190e | 2017-06-13 16:49:38 -0700 | [diff] [blame] | 294 | |
Ivan Khoronzhuk | 1d97c6c | 2019-10-11 03:28:01 +0300 | [diff] [blame] | 295 | -include $(BPF_SAMPLES_PATH)/Makefile.target |
| 296 | |
Naveen N. Rao | 128d151 | 2016-04-04 22:31:33 +0530 | [diff] [blame] | 297 | # asm/sysreg.h - inline assembly used by it is incompatible with llvm. |
| 298 | # But, there is no easy way to fix it, so just exclude it since it is |
Yang Shi | 30b50aa | 2015-11-12 14:07:46 -0800 | [diff] [blame] | 299 | # useless for BPF samples. |
Brenden Blanco | b88c06e | 2015-05-11 21:25:51 -0700 | [diff] [blame] | 300 | $(obj)/%.o: $(src)/%.c |
Jakub Kicinski | 768759e | 2018-05-14 22:35:06 -0700 | [diff] [blame] | 301 | @echo " CLANG-bpf " $@ |
Ivan Khoronzhuk | 2a560df | 2019-10-11 03:27:57 +0300 | [diff] [blame] | 302 | $(Q)$(CLANG) $(NOSTDINC_FLAGS) $(LINUXINCLUDE) $(BPF_EXTRA_CFLAGS) \ |
| 303 | -I$(obj) -I$(srctree)/tools/testing/selftests/bpf/ \ |
| 304 | -I$(srctree)/tools/lib/bpf/ \ |
Alexei Starovoitov | b1ae32d | 2018-05-13 12:32:22 -0700 | [diff] [blame] | 305 | -D__KERNEL__ -D__BPF_TRACING__ -Wno-unused-value -Wno-pointer-sign \ |
Ilya Leoshkevich | 81f522f | 2019-07-15 11:11:03 +0200 | [diff] [blame] | 306 | -D__TARGET_ARCH_$(SRCARCH) -Wno-compare-distinct-pointer-types \ |
Alexei Starovoitov | 69a9d09 | 2016-12-01 18:31:12 -0800 | [diff] [blame] | 307 | -Wno-gnu-variable-sized-type-not-at-end \ |
| 308 | -Wno-address-of-packed-member -Wno-tautological-compare \ |
Abhijit Ayarekar | 9db9583 | 2017-10-13 12:24:06 -0700 | [diff] [blame] | 309 | -Wno-unknown-warning-option $(CLANG_ARCH_ARGS) \ |
Yonghong Song | 6bf3bbe | 2019-01-12 15:04:30 -0800 | [diff] [blame] | 310 | -I$(srctree)/samples/bpf/ -include asm_goto_workaround.h \ |
Taeung Song | 9778cfd | 2018-07-26 19:13:44 +0900 | [diff] [blame] | 311 | -O2 -emit-llvm -c $< -o -| $(LLC) -march=bpf $(LLC_FLAGS) -filetype=obj -o $@ |
| 312 | ifeq ($(DWARF2BTF),y) |
| 313 | $(BTF_PAHOLE) -J $@ |
| 314 | endif |