Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | # SPDX-License-Identifier: GPL-2.0 |
Borislav Petkov | 9e4a664 | 2013-02-20 16:32:29 +0100 | [diff] [blame] | 2 | ifneq ($(O),) |
David Howells | bf35182 | 2012-11-05 21:02:08 +0000 | [diff] [blame] | 3 | ifeq ($(origin O), command line) |
Masami Hiramatsu | be40920 | 2020-03-07 03:32:58 +0900 | [diff] [blame] | 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) |
David Howells | bf35182 | 2012-11-05 21:02:08 +0000 | [diff] [blame] | 6 | OUTPUT := $(ABSOLUTE_O)/$(if $(subdir),$(subdir)/) |
Steven Rostedt | c883122 | 2012-08-13 10:23:02 -0400 | [diff] [blame] | 7 | COMMAND_O := O=$(ABSOLUTE_O) |
David Howells | bf35182 | 2012-11-05 21:02:08 +0000 | [diff] [blame] | 8 | ifeq ($(objtree),) |
| 9 | objtree := $(O) |
| 10 | endif |
Borislav Petkov | 98d89bf | 2012-04-11 18:36:14 +0200 | [diff] [blame] | 11 | endif |
Borislav Petkov | 9e4a664 | 2013-02-20 16:32:29 +0100 | [diff] [blame] | 12 | endif |
Borislav Petkov | 98d89bf | 2012-04-11 18:36:14 +0200 | [diff] [blame] | 13 | |
Borislav Petkov | 98d89bf | 2012-04-11 18:36:14 +0200 | [diff] [blame] | 14 | # check that the output directory actually exists |
Borislav Petkov | 9e4a664 | 2013-02-20 16:32:29 +0100 | [diff] [blame] | 15 | ifneq ($(OUTPUT),) |
Bjørn Forsman | 16f8259 | 2017-11-05 10:44:16 +0100 | [diff] [blame] | 16 | OUTDIR := $(shell cd $(OUTPUT) && pwd) |
Borislav Petkov | 98d89bf | 2012-04-11 18:36:14 +0200 | [diff] [blame] | 17 | $(if $(OUTDIR),, $(error output directory "$(OUTPUT)" does not exist)) |
| 18 | endif |
| 19 | |
| 20 | # |
| 21 | # Include saner warnings here, which can catch bugs: |
| 22 | # |
Borislav Petkov | d8caf3e | 2012-04-11 18:36:15 +0200 | [diff] [blame] | 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 |
Borislav Petkov | d8caf3e | 2012-04-11 18:36:15 +0200 | [diff] [blame] | 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 |
Borislav Petkov | 98d89bf | 2012-04-11 18:36:14 +0200 | [diff] [blame] | 41 | |
Martin Kelly | 7ed1c19 | 2018-02-21 14:45:12 -0800 | [diff] [blame] | 42 | # Makefiles suck: This macro sets a default value of $(2) for the |
| 43 | # variable named by $(1), unless the variable has been set by |
| 44 | # environment or command line. This is necessary for CC and AR |
| 45 | # because make sets default values, so the simpler ?= approach |
| 46 | # won't work as expected. |
| 47 | define allow-override |
| 48 | $(if $(or $(findstring environment,$(origin $(1))),\ |
| 49 | $(findstring command line,$(origin $(1)))),,\ |
| 50 | $(eval $(1) = $(2))) |
| 51 | endef |
| 52 | |
Yonghong Song | f62700c | 2021-04-13 08:34:19 -0700 | [diff] [blame^] | 53 | ifneq ($(LLVM),) |
| 54 | $(call allow-override,CC,clang) |
| 55 | $(call allow-override,AR,llvm-ar) |
| 56 | $(call allow-override,LD,ld.lld) |
| 57 | $(call allow-override,CXX,clang++) |
| 58 | $(call allow-override,STRIP,llvm-strip) |
| 59 | else |
Martin Kelly | 7ed1c19 | 2018-02-21 14:45:12 -0800 | [diff] [blame] | 60 | # Allow setting various cross-compile vars or setting CROSS_COMPILE as a prefix. |
| 61 | $(call allow-override,CC,$(CROSS_COMPILE)gcc) |
| 62 | $(call allow-override,AR,$(CROSS_COMPILE)ar) |
| 63 | $(call allow-override,LD,$(CROSS_COMPILE)ld) |
| 64 | $(call allow-override,CXX,$(CROSS_COMPILE)g++) |
| 65 | $(call allow-override,STRIP,$(CROSS_COMPILE)strip) |
Yonghong Song | f62700c | 2021-04-13 08:34:19 -0700 | [diff] [blame^] | 66 | endif |
| 67 | |
| 68 | CC_NO_CLANG := $(shell $(CC) -dM -E -x c /dev/null | grep -Fq "__clang__"; echo $$?) |
Martin Kelly | 7ed1c19 | 2018-02-21 14:45:12 -0800 | [diff] [blame] | 69 | |
Jean-Philippe Brucker | c8a950d | 2020-11-10 17:43:05 +0100 | [diff] [blame] | 70 | ifneq ($(LLVM),) |
| 71 | HOSTAR ?= llvm-ar |
| 72 | HOSTCC ?= clang |
| 73 | HOSTLD ?= ld.lld |
| 74 | else |
| 75 | HOSTAR ?= ar |
| 76 | HOSTCC ?= gcc |
| 77 | HOSTLD ?= ld |
| 78 | endif |
| 79 | |
Sedat Dilek | 211a741 | 2021-01-28 02:50:58 +0100 | [diff] [blame] | 80 | # Some tools require Clang, LLC and/or LLVM utils |
| 81 | CLANG ?= clang |
| 82 | LLC ?= llc |
| 83 | LLVM_CONFIG ?= llvm-config |
| 84 | LLVM_OBJCOPY ?= llvm-objcopy |
| 85 | LLVM_STRIP ?= llvm-strip |
| 86 | |
David Carrillo-Cisneros | 3866058 | 2017-08-27 00:54:40 -0700 | [diff] [blame] | 87 | ifeq ($(CC_NO_CLANG), 1) |
Arnaldo Carvalho de Melo | 093b75e | 2017-02-14 10:34:35 -0300 | [diff] [blame] | 88 | EXTRA_WARNINGS += -Wstrict-aliasing=3 |
| 89 | endif |
| 90 | |
Arnaldo Carvalho de Melo | 3337e68 | 2017-02-22 16:54:53 -0300 | [diff] [blame] | 91 | # Hack to avoid type-punned warnings on old systems such as RHEL5: |
| 92 | # We should be changing CFLAGS and checking gcc version, but this |
| 93 | # will do for now and keep the above -Wstrict-aliasing=3 in place |
| 94 | # in newer systems. |
| 95 | # Needed for the __raw_cmpxchg in tools/arch/x86/include/asm/cmpxchg.h |
Arnaldo Carvalho de Melo | 39e7317 | 2019-07-19 15:34:30 -0300 | [diff] [blame] | 96 | # |
| 97 | # See https://lkml.org/lkml/2006/11/28/253 and https://gcc.gnu.org/gcc-4.8/changes.html, |
| 98 | # that takes into account Linus's comments (search for Wshadow) for the reasoning about |
| 99 | # -Wshadow not being interesting before gcc 4.8. |
| 100 | |
Arnaldo Carvalho de Melo | 3337e68 | 2017-02-22 16:54:53 -0300 | [diff] [blame] | 101 | ifneq ($(filter 3.%,$(MAKE_VERSION)),) # make-3 |
| 102 | EXTRA_WARNINGS += -fno-strict-aliasing |
Arnaldo Carvalho de Melo | 39e7317 | 2019-07-19 15:34:30 -0300 | [diff] [blame] | 103 | EXTRA_WARNINGS += -Wno-shadow |
| 104 | else |
| 105 | EXTRA_WARNINGS += -Wshadow |
Arnaldo Carvalho de Melo | 3337e68 | 2017-02-22 16:54:53 -0300 | [diff] [blame] | 106 | endif |
| 107 | |
Borislav Petkov | 98d89bf | 2012-04-11 18:36:14 +0200 | [diff] [blame] | 108 | ifneq ($(findstring $(MAKEFLAGS), w),w) |
| 109 | PRINT_DIR = --no-print-directory |
| 110 | else |
| 111 | NO_SUBDIR = : |
| 112 | endif |
| 113 | |
Masahiro Yamada | 6f0fa58 | 2017-05-19 20:42:30 +0900 | [diff] [blame] | 114 | ifneq ($(findstring s,$(filter-out --%,$(MAKEFLAGS))),) |
Josh Poimboeuf | e572d08 | 2017-01-18 22:16:55 -0600 | [diff] [blame] | 115 | silent=1 |
| 116 | endif |
Josh Poimboeuf | e572d08 | 2017-01-18 22:16:55 -0600 | [diff] [blame] | 117 | |
David Howells | ca9dfc6 | 2012-11-05 15:15:24 +0000 | [diff] [blame] | 118 | # |
| 119 | # Define a callable command for descending to a new directory |
| 120 | # |
| 121 | # Call by doing: $(call descend,directory[,target]) |
| 122 | # |
| 123 | descend = \ |
David Howells | bf35182 | 2012-11-05 21:02:08 +0000 | [diff] [blame] | 124 | +mkdir -p $(OUTPUT)$(1) && \ |
David Howells | 2b73f65 | 2012-11-13 14:14:38 -0300 | [diff] [blame] | 125 | $(MAKE) $(COMMAND_O) subdir=$(if $(subdir),$(subdir)/$(1),$(1)) $(PRINT_DIR) -C $(1) $(2) |
David Howells | ca9dfc6 | 2012-11-05 15:15:24 +0000 | [diff] [blame] | 126 | |
David Howells | bf35182 | 2012-11-05 21:02:08 +0000 | [diff] [blame] | 127 | QUIET_SUBDIR0 = +$(MAKE) $(COMMAND_O) -C # space to separate -C and subdir |
Borislav Petkov | 98d89bf | 2012-04-11 18:36:14 +0200 | [diff] [blame] | 128 | QUIET_SUBDIR1 = |
| 129 | |
Josh Poimboeuf | e572d08 | 2017-01-18 22:16:55 -0600 | [diff] [blame] | 130 | ifneq ($(silent),1) |
Ingo Molnar | 65fb099 | 2013-10-09 11:49:27 +0200 | [diff] [blame] | 131 | ifneq ($(V),1) |
| 132 | QUIET_CC = @echo ' CC '$@; |
Jiri Olsa | bdebbac | 2013-12-19 14:42:03 +0100 | [diff] [blame] | 133 | QUIET_CC_FPIC = @echo ' CC FPIC '$@; |
Song Liu | 47c09d6 | 2020-03-09 10:32:15 -0700 | [diff] [blame] | 134 | QUIET_CLANG = @echo ' CLANG '$@; |
Ingo Molnar | 65fb099 | 2013-10-09 11:49:27 +0200 | [diff] [blame] | 135 | QUIET_AR = @echo ' AR '$@; |
| 136 | QUIET_LINK = @echo ' LINK '$@; |
| 137 | QUIET_MKDIR = @echo ' MKDIR '$@; |
| 138 | QUIET_GEN = @echo ' GEN '$@; |
Borislav Petkov | 98d89bf | 2012-04-11 18:36:14 +0200 | [diff] [blame] | 139 | QUIET_SUBDIR0 = +@subdir= |
Ingo Molnar | 65fb099 | 2013-10-09 11:49:27 +0200 | [diff] [blame] | 140 | QUIET_SUBDIR1 = ;$(NO_SUBDIR) \ |
| 141 | echo ' SUBDIR '$$subdir; \ |
Borislav Petkov | 98d89bf | 2012-04-11 18:36:14 +0200 | [diff] [blame] | 142 | $(MAKE) $(PRINT_DIR) -C $$subdir |
Ingo Molnar | 65fb099 | 2013-10-09 11:49:27 +0200 | [diff] [blame] | 143 | QUIET_FLEX = @echo ' FLEX '$@; |
| 144 | QUIET_BISON = @echo ' BISON '$@; |
Song Liu | fbcdaa1 | 2020-12-29 13:42:13 -0800 | [diff] [blame] | 145 | QUIET_GENSKEL = @echo ' GEN-SKEL '$@; |
David Howells | bf35182 | 2012-11-05 21:02:08 +0000 | [diff] [blame] | 146 | |
| 147 | descend = \ |
Ingo Molnar | 65fb099 | 2013-10-09 11:49:27 +0200 | [diff] [blame] | 148 | +@echo ' DESCEND '$(1); \ |
David Howells | bf35182 | 2012-11-05 21:02:08 +0000 | [diff] [blame] | 149 | mkdir -p $(OUTPUT)$(1) && \ |
David Howells | 2b73f65 | 2012-11-13 14:14:38 -0300 | [diff] [blame] | 150 | $(MAKE) $(COMMAND_O) subdir=$(if $(subdir),$(subdir)/$(1),$(1)) $(PRINT_DIR) -C $(1) $(2) |
Jiri Olsa | b7248de | 2013-12-19 14:42:00 +0100 | [diff] [blame] | 151 | |
| 152 | QUIET_CLEAN = @printf ' CLEAN %s\n' $1; |
| 153 | QUIET_INSTALL = @printf ' INSTALL %s\n' $1; |
Quentin Monnet | d324424 | 2017-12-07 15:00:18 -0800 | [diff] [blame] | 154 | QUIET_UNINST = @printf ' UNINST %s\n' $1; |
Ingo Molnar | 65fb099 | 2013-10-09 11:49:27 +0200 | [diff] [blame] | 155 | endif |
Borislav Petkov | 98d89bf | 2012-04-11 18:36:14 +0200 | [diff] [blame] | 156 | endif |
Rasmus Villemoes | 9564a8c | 2018-04-08 23:35:28 +0200 | [diff] [blame] | 157 | |
| 158 | pound := \# |