2 # SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
7 echo -e "\tTest the different ways of building bpftool."
10 echo -e "\t\t-j <n>:\tPass -j flag to 'make'."
17 # Assume script is located under tools/testing/selftests/bpf/. We want to start
18 # build attempts from the top of kernel repository.
19 SCRIPT_REL_PATH
=$
(realpath
--relative-to=$PWD $0)
20 SCRIPT_REL_DIR
=$
(dirname $SCRIPT_REL_PATH)
21 KDIR_ROOT_DIR
=$
(realpath
$PWD/$SCRIPT_REL_DIR/..
/..
/..
/..
/)
23 if [ ! -e tools
/bpf
/bpftool
/Makefile
]; then
24 echo -e "skip: bpftool files not found!\n"
31 # If one build fails, continue but return non-0 on exit.
33 if [ -d "$TMPDIR" ] ; then
38 trap return_value EXIT
41 local dir
=$
(realpath
$1)
44 # Returns non-null if file is found (and "false" is run)
45 find $dir -type f
-executable -name bpftool
-print -exec false
{} + && \
46 ERROR
=1 && printf "FAILURE: Did not find bpftool\n"
51 echo -e "command: make -s $* >/dev/null"
52 make $J -s $
* >/dev
/null
53 if [ $?
-ne 0 ] ; then
56 if [ $# -ge 1 ] ; then
62 if [ $# -ge 1 ] ; then
74 if [ $# -ge 2 ] ; then
75 ARGS
=${@:1:(($# - 1))}
78 echo -e "command: make -s $ARGS ${@: -1}=$TMPDIR/ >/dev/null"
79 make $J -s $ARGS ${@: -1}=$TMPDIR/ >/dev
/null
80 if [ $?
-ne 0 ] ; then
88 make_doc_and_clean
() {
90 echo -e "command: make -s $* doc >/dev/null"
91 RST2MAN_OPTS
="--exit-status=1" make $J -s $
* doc
92 if [ $?
-ne 0 ] ; then
94 printf "FAILURE: Errors or warnings when building documentation\n"
97 if [ $# -ge 1 ] ; then
105 echo "Trying to build bpftool"
106 echo -e "... through kbuild\n"
108 if [ -f ".config" ] ; then
109 make_and_clean tools
/bpf
111 ## $OUTPUT is overwritten in kbuild Makefile, and thus cannot be passed
112 ## down from toplevel Makefile to bpftool's Makefile.
114 # make_with_tmpdir tools/bpf OUTPUT
115 echo -e "skip: make tools/bpf OUTPUT=<dir> (not supported)\n"
117 make_with_tmpdir tools
/bpf O
119 echo -e "skip: make tools/bpf (no .config found)\n"
120 echo -e "skip: make tools/bpf OUTPUT=<dir> (not supported)\n"
121 echo -e "skip: make tools/bpf O=<dir> (no .config found)\n"
124 echo -e "... from kernel source tree\n"
126 make_and_clean
-C tools
/bpf
/bpftool
128 make_with_tmpdir
-C tools
/bpf
/bpftool OUTPUT
130 make_with_tmpdir
-C tools
/bpf
/bpftool O
132 echo -e "... from tools/\n"
137 ## In tools/bpf/Makefile, function "descend" is called and passes $(O) and
138 ## $(OUTPUT). We would like $(OUTPUT) to have "bpf/bpftool/" appended before
139 ## calling bpftool's Makefile, but this is not the case as the "descend"
140 ## function focuses on $(O)/$(subdir). However, in the present case, updating
141 ## $(O) to have $(OUTPUT) recomputed from it in bpftool's Makefile does not
142 ## work, because $(O) is not defined from command line and $(OUTPUT) is not
143 ## updated in tools/scripts/Makefile.include.
145 ## Workarounds would require to a) edit "descend" or use an alternative way to
146 ## call bpftool's Makefile, b) modify the conditions to update $(OUTPUT) and
147 ## other variables in tools/scripts/Makefile.include (at the risk of breaking
148 ## the build of other tools), or c) append manually the "bpf/bpftool" suffix to
149 ## $(OUTPUT) in bpf's Makefile, which may break if targets for other directories
150 ## use "descend" in the future.
152 # make_with_tmpdir bpf OUTPUT
153 echo -e "skip: make bpf OUTPUT=<dir> (not supported)\n"
155 make_with_tmpdir bpf O
157 echo -e "... from bpftool's dir\n"
162 make_with_tmpdir OUTPUT
166 echo -e "Checking documentation build\n"
167 # From tools/bpf/bpftool