samples/bpf: stress test bpf_get_stackid
[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
a6ffe7b9 19hostprogs-y += offwaketime
9d8b612d 20hostprogs-y += spintest
3c731eba
AS
21
22test_verifier-objs := test_verifier.o libbpf.o
ffb65f27 23test_maps-objs := test_maps.o libbpf.o
03f4723e 24sock_example-objs := sock_example.o libbpf.o
42984d7c 25fds_example-objs := bpf_load.o libbpf.o fds_example.o
a8085782 26sockex1-objs := bpf_load.o libbpf.o sockex1_user.o
fbe33108 27sockex2-objs := bpf_load.o libbpf.o sockex2_user.o
530b2c86 28sockex3-objs := bpf_load.o libbpf.o sockex3_user.o
b896c4f9 29tracex1-objs := bpf_load.o libbpf.o tracex1_user.o
d822a192 30tracex2-objs := bpf_load.o libbpf.o tracex2_user.o
5c7fc2d2 31tracex3-objs := bpf_load.o libbpf.o tracex3_user.o
9811e353 32tracex4-objs := bpf_load.o libbpf.o tracex4_user.o
5bacd780 33tracex5-objs := bpf_load.o libbpf.o tracex5_user.o
47efb302 34tracex6-objs := bpf_load.o libbpf.o tracex6_user.o
39111695 35trace_output-objs := bpf_load.o libbpf.o trace_output_user.o
0fb1170e 36lathist-objs := bpf_load.o libbpf.o lathist_user.o
a6ffe7b9 37offwaketime-objs := bpf_load.o libbpf.o offwaketime_user.o
9d8b612d 38spintest-objs := bpf_load.o libbpf.o spintest_user.o
3c731eba
AS
39
40# Tell kbuild to always build the programs
41always := $(hostprogs-y)
a8085782 42always += sockex1_kern.o
fbe33108 43always += sockex2_kern.o
530b2c86 44always += sockex3_kern.o
b896c4f9 45always += tracex1_kern.o
d822a192 46always += tracex2_kern.o
5c7fc2d2 47always += tracex3_kern.o
9811e353 48always += tracex4_kern.o
5bacd780 49always += tracex5_kern.o
47efb302 50always += tracex6_kern.o
39111695 51always += trace_output_kern.o
91bc4822 52always += tcbpf1_kern.o
0fb1170e 53always += lathist_kern.o
a6ffe7b9 54always += offwaketime_kern.o
9d8b612d 55always += spintest_kern.o
3c731eba
AS
56
57HOSTCFLAGS += -I$(objtree)/usr/include
a8085782
AS
58
59HOSTCFLAGS_bpf_load.o += -I$(objtree)/usr/include -Wno-unused-variable
42984d7c 60HOSTLOADLIBES_fds_example += -lelf
a8085782 61HOSTLOADLIBES_sockex1 += -lelf
fbe33108 62HOSTLOADLIBES_sockex2 += -lelf
530b2c86 63HOSTLOADLIBES_sockex3 += -lelf
b896c4f9 64HOSTLOADLIBES_tracex1 += -lelf
d822a192 65HOSTLOADLIBES_tracex2 += -lelf
5c7fc2d2 66HOSTLOADLIBES_tracex3 += -lelf
9811e353 67HOSTLOADLIBES_tracex4 += -lelf -lrt
5bacd780 68HOSTLOADLIBES_tracex5 += -lelf
47efb302 69HOSTLOADLIBES_tracex6 += -lelf
39111695 70HOSTLOADLIBES_trace_output += -lelf -lrt
0fb1170e 71HOSTLOADLIBES_lathist += -lelf
a6ffe7b9 72HOSTLOADLIBES_offwaketime += -lelf
9d8b612d 73HOSTLOADLIBES_spintest += -lelf
a8085782
AS
74
75# point this to your LLVM backend with bpf support
76LLC=$(srctree)/tools/bpf/llvm/bld/Debug+Asserts/bin/llc
77
30b50aa6
YS
78# asm/sysreg.h inline assmbly used by it is incompatible with llvm.
79# But, ehere is not easy way to fix it, so just exclude it since it is
80# useless for BPF samples.
b88c06e3 81$(obj)/%.o: $(src)/%.c
a8085782 82 clang $(NOSTDINC_FLAGS) $(LINUXINCLUDE) $(EXTRA_CFLAGS) \
30b50aa6 83 -D__KERNEL__ -D__ASM_SYSREG_H -Wno-unused-value -Wno-pointer-sign \
a8085782 84 -O2 -emit-llvm -c $< -o -| $(LLC) -march=bpf -filetype=obj -o $@
39111695 85 clang $(NOSTDINC_FLAGS) $(LINUXINCLUDE) $(EXTRA_CFLAGS) \
30b50aa6 86 -D__KERNEL__ -D__ASM_SYSREG_H -Wno-unused-value -Wno-pointer-sign \
39111695 87 -O2 -emit-llvm -c $< -o -| $(LLC) -march=bpf -filetype=asm -o $@.s