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