Commit | Line | Data |
---|---|---|
b2441318 | 1 | # SPDX-License-Identifier: GPL-2.0 |
9e4a6648 | 2 | ifneq ($(O),) |
bf35182f | 3 | ifeq ($(origin O), command line) |
be40920f MH |
4 | dummy := $(if $(shell cd $(PWD); test -d $(O) || echo $(O)),$(error O=$(O) does not exist),) |
5 | ABSOLUTE_O := $(shell cd $(PWD); cd $(O) ; pwd) | |
bf35182f | 6 | OUTPUT := $(ABSOLUTE_O)/$(if $(subdir),$(subdir)/) |
c883122a | 7 | COMMAND_O := O=$(ABSOLUTE_O) |
bf35182f DH |
8 | ifeq ($(objtree),) |
9 | objtree := $(O) | |
10 | endif | |
98d89bfd | 11 | endif |
9e4a6648 | 12 | endif |
98d89bfd | 13 | |
98d89bfd | 14 | # check that the output directory actually exists |
9e4a6648 | 15 | ifneq ($(OUTPUT),) |
16f8259c | 16 | OUTDIR := $(shell cd $(OUTPUT) && pwd) |
98d89bfd BP |
17 | $(if $(OUTDIR),, $(error output directory "$(OUTPUT)" does not exist)) |
18 | endif | |
19 | ||
20 | # | |
21 | # Include saner warnings here, which can catch bugs: | |
22 | # | |
d8caf3eb BP |
23 | EXTRA_WARNINGS := -Wbad-function-cast |
24 | EXTRA_WARNINGS += -Wdeclaration-after-statement | |
25 | EXTRA_WARNINGS += -Wformat-security | |
26 | EXTRA_WARNINGS += -Wformat-y2k | |
27 | EXTRA_WARNINGS += -Winit-self | |
28 | EXTRA_WARNINGS += -Wmissing-declarations | |
29 | EXTRA_WARNINGS += -Wmissing-prototypes | |
30 | EXTRA_WARNINGS += -Wnested-externs | |
31 | EXTRA_WARNINGS += -Wno-system-headers | |
32 | EXTRA_WARNINGS += -Wold-style-definition | |
33 | EXTRA_WARNINGS += -Wpacked | |
34 | EXTRA_WARNINGS += -Wredundant-decls | |
d8caf3eb BP |
35 | EXTRA_WARNINGS += -Wstrict-prototypes |
36 | EXTRA_WARNINGS += -Wswitch-default | |
37 | EXTRA_WARNINGS += -Wswitch-enum | |
38 | EXTRA_WARNINGS += -Wundef | |
39 | EXTRA_WARNINGS += -Wwrite-strings | |
40 | EXTRA_WARNINGS += -Wformat | |
d1d1a2cd | 41 | EXTRA_WARNINGS += -Wno-type-limits |
98d89bfd | 42 | |
7ed1c190 MK |
43 | # Makefiles suck: This macro sets a default value of $(2) for the |
44 | # variable named by $(1), unless the variable has been set by | |
45 | # environment or command line. This is necessary for CC and AR | |
46 | # because make sets default values, so the simpler ?= approach | |
47 | # won't work as expected. | |
48 | define allow-override | |
49 | $(if $(or $(findstring environment,$(origin $(1))),\ | |
50 | $(findstring command line,$(origin $(1)))),,\ | |
51 | $(eval $(1) = $(2))) | |
52 | endef | |
53 | ||
f62700ce YS |
54 | ifneq ($(LLVM),) |
55 | $(call allow-override,CC,clang) | |
56 | $(call allow-override,AR,llvm-ar) | |
57 | $(call allow-override,LD,ld.lld) | |
58 | $(call allow-override,CXX,clang++) | |
59 | $(call allow-override,STRIP,llvm-strip) | |
60 | else | |
7ed1c190 MK |
61 | # Allow setting various cross-compile vars or setting CROSS_COMPILE as a prefix. |
62 | $(call allow-override,CC,$(CROSS_COMPILE)gcc) | |
63 | $(call allow-override,AR,$(CROSS_COMPILE)ar) | |
64 | $(call allow-override,LD,$(CROSS_COMPILE)ld) | |
65 | $(call allow-override,CXX,$(CROSS_COMPILE)g++) | |
66 | $(call allow-override,STRIP,$(CROSS_COMPILE)strip) | |
f62700ce YS |
67 | endif |
68 | ||
69 | CC_NO_CLANG := $(shell $(CC) -dM -E -x c /dev/null | grep -Fq "__clang__"; echo $$?) | |
7ed1c190 | 70 | |
c8a950d0 JPB |
71 | ifneq ($(LLVM),) |
72 | HOSTAR ?= llvm-ar | |
73 | HOSTCC ?= clang | |
74 | HOSTLD ?= ld.lld | |
75 | else | |
76 | HOSTAR ?= ar | |
77 | HOSTCC ?= gcc | |
78 | HOSTLD ?= ld | |
79 | endif | |
80 | ||
211a741c SD |
81 | # Some tools require Clang, LLC and/or LLVM utils |
82 | CLANG ?= clang | |
83 | LLC ?= llc | |
84 | LLVM_CONFIG ?= llvm-config | |
85 | LLVM_OBJCOPY ?= llvm-objcopy | |
86 | LLVM_STRIP ?= llvm-strip | |
87 | ||
3866058e | 88 | ifeq ($(CC_NO_CLANG), 1) |
093b75ef | 89 | EXTRA_WARNINGS += -Wstrict-aliasing=3 |
cebdb737 JPB |
90 | |
91 | else ifneq ($(CROSS_COMPILE),) | |
92 | CLANG_CROSS_FLAGS := --target=$(notdir $(CROSS_COMPILE:%-=%)) | |
b7892f7d | 93 | GCC_TOOLCHAIN_DIR := $(dir $(shell which $(CROSS_COMPILE)gcc 2>/dev/null)) |
cebdb737 JPB |
94 | ifneq ($(GCC_TOOLCHAIN_DIR),) |
95 | CLANG_CROSS_FLAGS += --prefix=$(GCC_TOOLCHAIN_DIR)$(notdir $(CROSS_COMPILE)) | |
96 | CLANG_CROSS_FLAGS += --sysroot=$(shell $(CROSS_COMPILE)gcc -print-sysroot) | |
97 | CLANG_CROSS_FLAGS += --gcc-toolchain=$(realpath $(GCC_TOOLCHAIN_DIR)/..) | |
98 | endif # GCC_TOOLCHAIN_DIR | |
99 | CFLAGS += $(CLANG_CROSS_FLAGS) | |
100 | AFLAGS += $(CLANG_CROSS_FLAGS) | |
101 | endif # CROSS_COMPILE | |
093b75ef | 102 | |
3337e682 ACM |
103 | # Hack to avoid type-punned warnings on old systems such as RHEL5: |
104 | # We should be changing CFLAGS and checking gcc version, but this | |
105 | # will do for now and keep the above -Wstrict-aliasing=3 in place | |
106 | # in newer systems. | |
107 | # Needed for the __raw_cmpxchg in tools/arch/x86/include/asm/cmpxchg.h | |
39e7317e | 108 | # |
c9491aad KC |
109 | # See https://lore.kernel.org/lkml/9a8748490611281710g78402fbeh8ff7fcc162dbcbca@mail.gmail.com/ |
110 | # and https://gcc.gnu.org/gcc-4.8/changes.html, | |
39e7317e ACM |
111 | # that takes into account Linus's comments (search for Wshadow) for the reasoning about |
112 | # -Wshadow not being interesting before gcc 4.8. | |
113 | ||
3337e682 ACM |
114 | ifneq ($(filter 3.%,$(MAKE_VERSION)),) # make-3 |
115 | EXTRA_WARNINGS += -fno-strict-aliasing | |
39e7317e ACM |
116 | EXTRA_WARNINGS += -Wno-shadow |
117 | else | |
118 | EXTRA_WARNINGS += -Wshadow | |
3337e682 ACM |
119 | endif |
120 | ||
98d89bfd BP |
121 | ifneq ($(findstring $(MAKEFLAGS), w),w) |
122 | PRINT_DIR = --no-print-directory | |
123 | else | |
124 | NO_SUBDIR = : | |
125 | endif | |
126 | ||
6f0fa58e | 127 | ifneq ($(findstring s,$(filter-out --%,$(MAKEFLAGS))),) |
e572d088 JP |
128 | silent=1 |
129 | endif | |
e572d088 | 130 | |
ca9dfc6c DH |
131 | # |
132 | # Define a callable command for descending to a new directory | |
133 | # | |
134 | # Call by doing: $(call descend,directory[,target]) | |
135 | # | |
136 | descend = \ | |
bf35182f | 137 | +mkdir -p $(OUTPUT)$(1) && \ |
2b73f65d | 138 | $(MAKE) $(COMMAND_O) subdir=$(if $(subdir),$(subdir)/$(1),$(1)) $(PRINT_DIR) -C $(1) $(2) |
ca9dfc6c | 139 | |
bf35182f | 140 | QUIET_SUBDIR0 = +$(MAKE) $(COMMAND_O) -C # space to separate -C and subdir |
98d89bfd BP |
141 | QUIET_SUBDIR1 = |
142 | ||
e572d088 | 143 | ifneq ($(silent),1) |
65fb0992 | 144 | ifneq ($(V),1) |
c6de37dd KC |
145 | QUIET_CC = @echo ' CC '$@; |
146 | QUIET_CC_FPIC = @echo ' CC FPIC '$@; | |
147 | QUIET_CLANG = @echo ' CLANG '$@; | |
148 | QUIET_AR = @echo ' AR '$@; | |
149 | QUIET_LINK = @echo ' LINK '$@; | |
150 | QUIET_MKDIR = @echo ' MKDIR '$@; | |
151 | QUIET_GEN = @echo ' GEN '$@; | |
98d89bfd | 152 | QUIET_SUBDIR0 = +@subdir= |
65fb0992 | 153 | QUIET_SUBDIR1 = ;$(NO_SUBDIR) \ |
c6de37dd | 154 | echo ' SUBDIR '$$subdir; \ |
98d89bfd | 155 | $(MAKE) $(PRINT_DIR) -C $$subdir |
c6de37dd KC |
156 | QUIET_FLEX = @echo ' FLEX '$@; |
157 | QUIET_BISON = @echo ' BISON '$@; | |
158 | QUIET_GENSKEL = @echo ' GENSKEL '$@; | |
bf35182f DH |
159 | |
160 | descend = \ | |
c6de37dd | 161 | +@echo ' DESCEND '$(1); \ |
bf35182f | 162 | mkdir -p $(OUTPUT)$(1) && \ |
2b73f65d | 163 | $(MAKE) $(COMMAND_O) subdir=$(if $(subdir),$(subdir)/$(1),$(1)) $(PRINT_DIR) -C $(1) $(2) |
b7248def | 164 | |
c6de37dd KC |
165 | QUIET_CLEAN = @printf ' CLEAN %s\n' $1; |
166 | QUIET_INSTALL = @printf ' INSTALL %s\n' $1; | |
167 | QUIET_UNINST = @printf ' UNINST %s\n' $1; | |
65fb0992 | 168 | endif |
98d89bfd | 169 | endif |
9564a8cf RV |
170 | |
171 | pound := \# |