bpf: introduce BPF_MAP_TYPE_STACK_TRACE
[linux-2.6-block.git] / samples / bpf / Makefile
CommitLineData
3c731eba
AS
1# kbuild trick to avoid linker error. Can be omitted if a module is built.
2obj- := dummy.o
3
4# List of programs to build
ffb65f27 5hostprogs-y := test_verifier test_maps
03f4723e 6hostprogs-y += sock_example
42984d7c 7hostprogs-y += fds_example
a8085782 8hostprogs-y += sockex1
fbe33108 9hostprogs-y += sockex2
530b2c86 10hostprogs-y += sockex3
b896c4f9 11hostprogs-y += tracex1
d822a192 12hostprogs-y += tracex2
5c7fc2d2 13hostprogs-y += tracex3
9811e353 14hostprogs-y += tracex4
5bacd780 15hostprogs-y += tracex5
47efb302 16hostprogs-y += tracex6
39111695 17hostprogs-y += trace_output
0fb1170e 18hostprogs-y += lathist
3c731eba
AS
19
20test_verifier-objs := test_verifier.o libbpf.o
ffb65f27 21test_maps-objs := test_maps.o libbpf.o
03f4723e 22sock_example-objs := sock_example.o libbpf.o
42984d7c 23fds_example-objs := bpf_load.o libbpf.o fds_example.o
a8085782 24sockex1-objs := bpf_load.o libbpf.o sockex1_user.o
fbe33108 25sockex2-objs := bpf_load.o libbpf.o sockex2_user.o
530b2c86 26sockex3-objs := bpf_load.o libbpf.o sockex3_user.o
b896c4f9 27tracex1-objs := bpf_load.o libbpf.o tracex1_user.o
d822a192 28tracex2-objs := bpf_load.o libbpf.o tracex2_user.o
5c7fc2d2 29tracex3-objs := bpf_load.o libbpf.o tracex3_user.o
9811e353 30tracex4-objs := bpf_load.o libbpf.o tracex4_user.o
5bacd780 31tracex5-objs := bpf_load.o libbpf.o tracex5_user.o
47efb302 32tracex6-objs := bpf_load.o libbpf.o tracex6_user.o
39111695 33trace_output-objs := bpf_load.o libbpf.o trace_output_user.o
0fb1170e 34lathist-objs := bpf_load.o libbpf.o lathist_user.o
3c731eba
AS
35
36# Tell kbuild to always build the programs
37always := $(hostprogs-y)
a8085782 38always += sockex1_kern.o
fbe33108 39always += sockex2_kern.o
530b2c86 40always += sockex3_kern.o
b896c4f9 41always += tracex1_kern.o
d822a192 42always += tracex2_kern.o
5c7fc2d2 43always += tracex3_kern.o
9811e353 44always += tracex4_kern.o
5bacd780 45always += tracex5_kern.o
47efb302 46always += tracex6_kern.o
39111695 47always += trace_output_kern.o
91bc4822 48always += tcbpf1_kern.o
0fb1170e 49always += lathist_kern.o
3c731eba
AS
50
51HOSTCFLAGS += -I$(objtree)/usr/include
a8085782
AS
52
53HOSTCFLAGS_bpf_load.o += -I$(objtree)/usr/include -Wno-unused-variable
42984d7c 54HOSTLOADLIBES_fds_example += -lelf
a8085782 55HOSTLOADLIBES_sockex1 += -lelf
fbe33108 56HOSTLOADLIBES_sockex2 += -lelf
530b2c86 57HOSTLOADLIBES_sockex3 += -lelf
b896c4f9 58HOSTLOADLIBES_tracex1 += -lelf
d822a192 59HOSTLOADLIBES_tracex2 += -lelf
5c7fc2d2 60HOSTLOADLIBES_tracex3 += -lelf
9811e353 61HOSTLOADLIBES_tracex4 += -lelf -lrt
5bacd780 62HOSTLOADLIBES_tracex5 += -lelf
47efb302 63HOSTLOADLIBES_tracex6 += -lelf
39111695 64HOSTLOADLIBES_trace_output += -lelf -lrt
0fb1170e 65HOSTLOADLIBES_lathist += -lelf
a8085782
AS
66
67# point this to your LLVM backend with bpf support
68LLC=$(srctree)/tools/bpf/llvm/bld/Debug+Asserts/bin/llc
69
30b50aa6
YS
70# asm/sysreg.h inline assmbly used by it is incompatible with llvm.
71# But, ehere is not easy way to fix it, so just exclude it since it is
72# useless for BPF samples.
b88c06e3 73$(obj)/%.o: $(src)/%.c
a8085782 74 clang $(NOSTDINC_FLAGS) $(LINUXINCLUDE) $(EXTRA_CFLAGS) \
30b50aa6 75 -D__KERNEL__ -D__ASM_SYSREG_H -Wno-unused-value -Wno-pointer-sign \
a8085782 76 -O2 -emit-llvm -c $< -o -| $(LLC) -march=bpf -filetype=obj -o $@
39111695 77 clang $(NOSTDINC_FLAGS) $(LINUXINCLUDE) $(EXTRA_CFLAGS) \
30b50aa6 78 -D__KERNEL__ -D__ASM_SYSREG_H -Wno-unused-value -Wno-pointer-sign \
39111695 79 -O2 -emit-llvm -c $< -o -| $(LLC) -march=bpf -filetype=asm -o $@.s