mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-27 04:54:41 +08:00
507e590da3
Programs and documentation not managed by package manager are generally installed under /usr/local/, instead of the user's home directory. In particular, `man` is generally able to find manual pages under `/usr/local/share/man`. bpftool generally follows perf's example, and perf installs to home directory. However bpftool requires root credentials, so it seems sensible to follow the more common convention of installing files under /usr/local instead. So, make /usr/local the default prefix for installing the binary with `make install`, and the documentation with `make doc-install`. Also, create /usr/local/sbin if it does not exist. Note that the bash-completion file, however, is still installed under /usr/share/bash-completion/completions, as the default setup for bash does not attempt to load completion files under /usr/local/. Reported-by: David Beckett <david.beckett@netronome.com> Signed-off-by: Quentin Monnet <quentin.monnet@netronome.com> Acked-by: Jakub Kicinski <jakub.kicinski@netronome.com> Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
94 lines
2.1 KiB
Makefile
94 lines
2.1 KiB
Makefile
include ../../scripts/Makefile.include
|
|
|
|
include ../../scripts/utilities.mak
|
|
|
|
ifeq ($(srctree),)
|
|
srctree := $(patsubst %/,%,$(dir $(CURDIR)))
|
|
srctree := $(patsubst %/,%,$(dir $(srctree)))
|
|
srctree := $(patsubst %/,%,$(dir $(srctree)))
|
|
#$(info Determined 'srctree' to be $(srctree))
|
|
endif
|
|
|
|
ifneq ($(objtree),)
|
|
#$(info Determined 'objtree' to be $(objtree))
|
|
endif
|
|
|
|
ifneq ($(OUTPUT),)
|
|
#$(info Determined 'OUTPUT' to be $(OUTPUT))
|
|
# Adding $(OUTPUT) as a directory to look for source files,
|
|
# because use generated output files as sources dependency
|
|
# for flex/bison parsers.
|
|
VPATH += $(OUTPUT)
|
|
export VPATH
|
|
endif
|
|
|
|
ifeq ($(V),1)
|
|
Q =
|
|
else
|
|
Q = @
|
|
endif
|
|
|
|
BPF_DIR = $(srctree)/tools/lib/bpf/
|
|
|
|
ifneq ($(OUTPUT),)
|
|
BPF_PATH=$(OUTPUT)
|
|
else
|
|
BPF_PATH=$(BPF_DIR)
|
|
endif
|
|
|
|
LIBBPF = $(BPF_PATH)libbpf.a
|
|
|
|
$(LIBBPF): FORCE
|
|
$(Q)$(MAKE) -C $(BPF_DIR) OUTPUT=$(OUTPUT) $(OUTPUT)libbpf.a FEATURES_DUMP=$(FEATURE_DUMP_EXPORT)
|
|
|
|
$(LIBBPF)-clean:
|
|
$(call QUIET_CLEAN, libbpf)
|
|
$(Q)$(MAKE) -C $(BPF_DIR) OUTPUT=$(OUTPUT) clean >/dev/null
|
|
|
|
prefix = /usr/local
|
|
bash_compdir ?= /usr/share/bash-completion/completions
|
|
|
|
CC = gcc
|
|
|
|
CFLAGS += -O2
|
|
CFLAGS += -W -Wall -Wextra -Wno-unused-parameter -Wshadow
|
|
CFLAGS += -D__EXPORTED_HEADERS__ -I$(srctree)/tools/include/uapi -I$(srctree)/tools/include -I$(srctree)/tools/lib/bpf -I$(srctree)/kernel/bpf/
|
|
LIBS = -lelf -lbfd -lopcodes $(LIBBPF)
|
|
|
|
include $(wildcard *.d)
|
|
|
|
all: $(OUTPUT)bpftool
|
|
|
|
SRCS=$(wildcard *.c)
|
|
OBJS=$(patsubst %.c,$(OUTPUT)%.o,$(SRCS)) $(OUTPUT)disasm.o
|
|
|
|
$(OUTPUT)disasm.o: $(srctree)/kernel/bpf/disasm.c
|
|
$(QUIET_CC)$(COMPILE.c) -MMD -o $@ $<
|
|
|
|
$(OUTPUT)bpftool: $(OBJS) $(LIBBPF)
|
|
$(QUIET_LINK)$(CC) $(CFLAGS) -o $@ $^ $(LIBS)
|
|
|
|
$(OUTPUT)%.o: %.c
|
|
$(QUIET_CC)$(COMPILE.c) -MMD -o $@ $<
|
|
|
|
clean: $(LIBBPF)-clean
|
|
$(call QUIET_CLEAN, bpftool)
|
|
$(Q)rm -rf $(OUTPUT)bpftool $(OUTPUT)*.o $(OUTPUT)*.d
|
|
|
|
install:
|
|
install -m 0755 -d $(prefix)/sbin
|
|
install $(OUTPUT)bpftool $(prefix)/sbin/bpftool
|
|
install -m 0755 -d $(bash_compdir)
|
|
install -m 0644 bash-completion/bpftool $(bash_compdir)
|
|
|
|
doc:
|
|
$(Q)$(MAKE) -C Documentation/
|
|
|
|
doc-install:
|
|
$(Q)$(MAKE) -C Documentation/ install
|
|
|
|
FORCE:
|
|
|
|
.PHONY: all clean FORCE
|
|
.DEFAULT_GOAL := all
|