1# SPDX-License-Identifier: GPL-2.0 2include ../scripts/Makefile.include 3include ../scripts/Makefile.arch 4 5ifeq ($(SRCARCH),x86) 6 BUILD_ORC := y 7 ARCH_HAS_KLP := y 8endif 9 10ifeq ($(SRCARCH),loongarch) 11 BUILD_ORC := y 12endif 13 14ifeq ($(ARCH_HAS_KLP),y) 15 HAVE_XXHASH = $(shell echo "int main() {}" | \ 16 $(HOSTCC) -xc - -o /dev/null -lxxhash 2> /dev/null && echo y || echo n) 17 ifeq ($(HAVE_XXHASH),y) 18 BUILD_KLP := y 19 LIBXXHASH_CFLAGS := $(shell $(HOSTPKG_CONFIG) libxxhash --cflags 2>/dev/null) \ 20 -DBUILD_KLP 21 LIBXXHASH_LIBS := $(shell $(HOSTPKG_CONFIG) libxxhash --libs 2>/dev/null || echo -lxxhash) 22 endif 23endif 24 25export BUILD_ORC BUILD_KLP 26 27ifeq ($(srctree),) 28srctree := $(patsubst %/,%,$(dir $(CURDIR))) 29srctree := $(patsubst %/,%,$(dir $(srctree))) 30endif 31 32LIBSUBCMD_DIR = $(srctree)/tools/lib/subcmd/ 33ifneq ($(OUTPUT),) 34 LIBSUBCMD_OUTPUT = $(abspath $(OUTPUT))/libsubcmd 35else 36 LIBSUBCMD_OUTPUT = $(CURDIR)/libsubcmd 37endif 38LIBSUBCMD = $(LIBSUBCMD_OUTPUT)/libsubcmd.a 39 40OBJTOOL := $(OUTPUT)objtool 41OBJTOOL_IN := $(OBJTOOL)-in.o 42 43LIBELF_FLAGS := $(shell $(HOSTPKG_CONFIG) libelf --cflags 2>/dev/null) 44LIBELF_LIBS := $(shell $(HOSTPKG_CONFIG) libelf --libs 2>/dev/null || echo -lelf) 45 46all: $(OBJTOOL) 47 48WARNINGS := -Werror -Wall -Wextra -Wmissing-prototypes \ 49 -Wmissing-declarations -Wwrite-strings \ 50 -Wno-implicit-fallthrough -Wno-sign-compare \ 51 -Wno-unused-parameter 52 53INCLUDES := -I$(srctree)/tools/include \ 54 -I$(srctree)/tools/include/uapi \ 55 -I$(srctree)/tools/arch/$(HOSTARCH)/include/uapi \ 56 -I$(srctree)/tools/arch/$(SRCARCH)/include \ 57 -I$(srctree)/tools/objtool/include \ 58 -I$(srctree)/tools/objtool/arch/$(SRCARCH)/include \ 59 -I$(LIBSUBCMD_OUTPUT)/include 60 61OBJTOOL_CFLAGS := -std=gnu11 -fomit-frame-pointer -O2 -g $(WARNINGS) \ 62 $(INCLUDES) $(LIBELF_FLAGS) $(LIBXXHASH_CFLAGS) $(HOSTCFLAGS) 63 64OBJTOOL_LDFLAGS := $(LIBSUBCMD) $(LIBELF_LIBS) $(LIBXXHASH_LIBS) $(HOSTLDFLAGS) 65 66# Allow old libelf to be used: 67elfshdr := $(shell echo '$(pound)include <libelf.h>' | $(HOSTCC) $(OBJTOOL_CFLAGS) -x c -E - 2>/dev/null | grep elf_getshdr) 68OBJTOOL_CFLAGS += $(if $(elfshdr),,-DLIBELF_USE_DEPRECATED) 69 70# Always want host compilation. 71HOST_OVERRIDES := CC="$(HOSTCC)" LD="$(HOSTLD)" AR="$(HOSTAR)" 72 73AWK = awk 74MKDIR = mkdir 75 76export srctree OUTPUT CFLAGS SRCARCH AWK 77include $(srctree)/tools/build/Makefile.include 78 79$(OBJTOOL_IN): fixdep $(LIBSUBCMD) FORCE 80 $(Q)$(CONFIG_SHELL) ./sync-check.sh 81 $(Q)$(MAKE) $(build)=objtool $(HOST_OVERRIDES) CFLAGS="$(OBJTOOL_CFLAGS)" \ 82 LDFLAGS="$(OBJTOOL_LDFLAGS)" 83 84 85$(OBJTOOL): $(LIBSUBCMD) $(OBJTOOL_IN) 86 $(QUIET_LINK)$(HOSTCC) $(OBJTOOL_IN) $(OBJTOOL_LDFLAGS) -o $@ 87 88 89$(LIBSUBCMD_OUTPUT): 90 $(Q)$(MKDIR) -p $@ 91 92$(LIBSUBCMD): fixdep $(LIBSUBCMD_OUTPUT) FORCE 93 $(Q)$(MAKE) -C $(LIBSUBCMD_DIR) O=$(LIBSUBCMD_OUTPUT) \ 94 DESTDIR=$(LIBSUBCMD_OUTPUT) prefix= subdir= \ 95 $(HOST_OVERRIDES) EXTRA_CFLAGS="$(OBJTOOL_CFLAGS)" \ 96 $@ install_headers 97 98$(LIBSUBCMD)-clean: 99 $(call QUIET_CLEAN, libsubcmd) 100 $(Q)$(RM) -r -- $(LIBSUBCMD_OUTPUT) 101 102clean: $(LIBSUBCMD)-clean 103 $(call QUIET_CLEAN, objtool) $(RM) $(OBJTOOL) 104 $(Q)find $(OUTPUT) -name '*.o' -delete -o -name '\.*.cmd' -delete -o -name '\.*.d' -delete 105 $(Q)$(RM) $(OUTPUT)arch/x86/lib/inat-tables.c $(OUTPUT)fixdep 106 107FORCE: 108 109.PHONY: clean FORCE 110