1# SPDX-License-Identifier: GPL-2.0 2include ../scripts/Makefile.include 3include ../scripts/Makefile.arch 4 5ifeq ($(ARCH),x86_64) 6ARCH := x86 7endif 8 9# always use the host compiler 10HOSTCC ?= gcc 11HOSTLD ?= ld 12CC = $(HOSTCC) 13LD = $(HOSTLD) 14AR = ar 15 16ifeq ($(srctree),) 17srctree := $(patsubst %/,%,$(dir $(CURDIR))) 18srctree := $(patsubst %/,%,$(dir $(srctree))) 19endif 20 21SUBCMD_SRCDIR = $(srctree)/tools/lib/subcmd/ 22LIBSUBCMD_OUTPUT = $(if $(OUTPUT),$(OUTPUT),$(CURDIR)/) 23LIBSUBCMD = $(LIBSUBCMD_OUTPUT)libsubcmd.a 24 25OBJTOOL := $(OUTPUT)objtool 26OBJTOOL_IN := $(OBJTOOL)-in.o 27 28all: $(OBJTOOL) 29 30INCLUDES := -I$(srctree)/tools/include \ 31 -I$(srctree)/tools/arch/$(HOSTARCH)/include/uapi \ 32 -I$(srctree)/tools/objtool/arch/$(ARCH)/include 33WARNINGS := $(EXTRA_WARNINGS) -Wno-switch-default -Wno-switch-enum -Wno-packed 34CFLAGS += -Werror $(WARNINGS) $(KBUILD_HOSTCFLAGS) -g $(INCLUDES) 35LDFLAGS += -lelf $(LIBSUBCMD) $(KBUILD_HOSTLDFLAGS) 36 37# Allow old libelf to be used: 38elfshdr := $(shell echo '$(pound)include <libelf.h>' | $(CC) $(CFLAGS) -x c -E - | grep elf_getshdr) 39CFLAGS += $(if $(elfshdr),,-DLIBELF_USE_DEPRECATED) 40 41AWK = awk 42export srctree OUTPUT CFLAGS SRCARCH AWK 43include $(srctree)/tools/build/Makefile.include 44 45$(OBJTOOL_IN): fixdep FORCE 46 @$(MAKE) $(build)=objtool 47 48$(OBJTOOL): $(LIBSUBCMD) $(OBJTOOL_IN) 49 @$(CONFIG_SHELL) ./sync-check.sh 50 $(QUIET_LINK)$(CC) $(OBJTOOL_IN) $(LDFLAGS) -o $@ 51 52 53$(LIBSUBCMD): fixdep FORCE 54 $(Q)$(MAKE) -C $(SUBCMD_SRCDIR) OUTPUT=$(LIBSUBCMD_OUTPUT) 55 56clean: 57 $(call QUIET_CLEAN, objtool) $(RM) $(OBJTOOL) 58 $(Q)find $(OUTPUT) -name '*.o' -delete -o -name '\.*.cmd' -delete -o -name '\.*.d' -delete 59 $(Q)$(RM) $(OUTPUT)arch/x86/lib/inat-tables.c $(OUTPUT)fixdep 60 61FORCE: 62 63.PHONY: clean FORCE 64