]>
Commit | Line | Data |
---|---|---|
14cf11af PM |
1 | # This file is included by the global makefile so that you can add your own |
2 | # architecture-specific flags and dependencies. Remember to do have actions | |
3 | # for "archclean" and "archdep" for cleaning up and making dependencies for | |
4 | # this architecture. | |
5 | # | |
6 | # This file is subject to the terms and conditions of the GNU General Public | |
7 | # License. See the file "COPYING" in the main directory of this archive | |
8 | # for more details. | |
9 | # | |
10 | # Copyright (C) 1994 by Linus Torvalds | |
11 | # Changes for PPC by Gary Thomas | |
12 | # Rewritten by Cort Dougan and Paul Mackerras | |
13 | # | |
14 | ||
14cf11af PM |
15 | HAS_BIARCH := $(call cc-option-yn, -m32) |
16 | ||
14cf11af PM |
17 | # Set default 32 bits cross compilers for vdso and boot wrapper |
18 | CROSS32_COMPILE ?= | |
19 | ||
14cf11af PM |
20 | ifeq ($(HAS_BIARCH),y) |
21 | ifeq ($(CROSS32_COMPILE),) | |
4bf4f42a NP |
22 | ifdef CONFIG_PPC32 |
23 | # These options will be overridden by any -mcpu option that the CPU | |
24 | # or platform code sets later on the command line, but they are needed | |
25 | # to set a sane 32-bit cpu target for the 64-bit cross compiler which | |
26 | # may default to the wrong ISA. | |
27 | KBUILD_CFLAGS += -mcpu=powerpc | |
28 | KBUILD_AFLAGS += -mcpu=powerpc | |
29 | endif | |
14cf11af PM |
30 | endif |
31 | endif | |
32 | ||
ebd1d3b7 MM |
33 | ifdef CONFIG_PPC_BOOK3S_32 |
34 | KBUILD_CFLAGS += -mcpu=powerpc | |
35 | endif | |
36 | ||
ca786f83 | 37 | ifeq ($(CROSS_COMPILE),) |
8a5abdf8 | 38 | KBUILD_DEFCONFIG := $(shell uname -m)_defconfig |
ca786f83 AB |
39 | else |
40 | KBUILD_DEFCONFIG := ppc64_defconfig | |
41 | endif | |
8a5abdf8 | 42 | |
badf436f | 43 | ifdef CONFIG_PPC64 |
14cf11af PM |
44 | new_nm := $(shell if $(NM) --help 2>&1 | grep -- '--synthetic' > /dev/null; then echo y; else echo n; fi) |
45 | ||
46 | ifeq ($(new_nm),y) | |
47 | NM := $(NM) --synthetic | |
48 | endif | |
a0588015 | 49 | endif |
14cf11af | 50 | |
68201fbb ME |
51 | # BITS is used as extension for files which are available in a 32 bit |
52 | # and a 64 bit version to simplify shared Makefiles. | |
53 | # e.g.: obj-y += foo_$(BITS).o | |
54 | export BITS | |
55 | ||
56 | ifdef CONFIG_PPC64 | |
57 | BITS := 64 | |
58 | else | |
59 | BITS := 32 | |
14cf11af PM |
60 | endif |
61 | ||
57073e27 ME |
62 | machine-y = ppc |
63 | machine-$(CONFIG_PPC64) += 64 | |
64 | machine-$(CONFIG_CPU_LITTLE_ENDIAN) += le | |
65 | UTS_MACHINE := $(subst $(space),,$(machine-y)) | |
190554db | 66 | |
b40b2386 ME |
67 | # XXX This needs to be before we override LD below |
68 | ifdef CONFIG_PPC32 | |
69 | KBUILD_LDFLAGS_MODULE += arch/powerpc/lib/crtsavres.o | |
70 | else | |
5c45b528 | 71 | KBUILD_LDFLAGS_MODULE += -T $(srctree)/arch/powerpc/kernel/module.lds |
b40b2386 ME |
72 | ifeq ($(call ld-ifversion, -ge, 225000000, y),y) |
73 | # Have the linker provide sfpr if possible. | |
74 | # There is a corresponding test in arch/powerpc/lib/Makefile | |
75 | KBUILD_LDFLAGS_MODULE += --save-restore-funcs | |
76 | else | |
77 | KBUILD_LDFLAGS_MODULE += arch/powerpc/lib/crtsavres.o | |
78 | endif | |
79 | endif | |
80 | ||
badf436f | 81 | ifdef CONFIG_CPU_LITTLE_ENDIAN |
1421dc6d | 82 | KBUILD_CFLAGS += -mlittle-endian |
d503ac53 | 83 | KBUILD_LDFLAGS += -EL |
d72b0801 IM |
84 | LDEMULATION := lppc |
85 | GNUTARGET := powerpcle | |
86 | MULTIPLEWORD := -mno-multiple | |
d3d35d95 | 87 | KBUILD_CFLAGS_MODULE += $(call cc-option,-mno-save-toc-indirect) |
d72b0801 | 88 | else |
1421dc6d | 89 | KBUILD_CFLAGS += $(call cc-option,-mbig-endian) |
d503ac53 | 90 | KBUILD_LDFLAGS += -EB |
d72b0801 IM |
91 | LDEMULATION := ppc |
92 | GNUTARGET := powerpc | |
93 | MULTIPLEWORD := -mmultiple | |
94 | endif | |
95 | ||
4dc831aa NP |
96 | ifdef CONFIG_PPC64 |
97 | cflags-$(CONFIG_CPU_BIG_ENDIAN) += $(call cc-option,-mabi=elfv1) | |
98 | cflags-$(CONFIG_CPU_BIG_ENDIAN) += $(call cc-option,-mcall-aixdesc) | |
99 | aflags-$(CONFIG_CPU_BIG_ENDIAN) += $(call cc-option,-mabi=elfv1) | |
100 | aflags-$(CONFIG_CPU_LITTLE_ENDIAN) += -mabi=elfv2 | |
101 | endif | |
102 | ||
076f421d | 103 | ifndef CONFIG_CC_IS_CLANG |
164af597 ME |
104 | cflags-$(CONFIG_CPU_LITTLE_ENDIAN) += -mno-strict-align |
105 | endif | |
106 | ||
1421dc6d NP |
107 | cflags-$(CONFIG_CPU_BIG_ENDIAN) += $(call cc-option,-mbig-endian) |
108 | cflags-$(CONFIG_CPU_LITTLE_ENDIAN) += -mlittle-endian | |
164af597 ME |
109 | aflags-$(CONFIG_CPU_BIG_ENDIAN) += $(call cc-option,-mbig-endian) |
110 | aflags-$(CONFIG_CPU_LITTLE_ENDIAN) += -mlittle-endian | |
111 | ||
14cf11af | 112 | ifeq ($(HAS_BIARCH),y) |
1421dc6d NP |
113 | KBUILD_CFLAGS += -m$(BITS) |
114 | KBUILD_AFLAGS += -m$(BITS) -Wl,-a$(BITS) | |
d503ac53 | 115 | KBUILD_LDFLAGS += -m elf$(BITS)$(LDEMULATION) |
43c9127d | 116 | KBUILD_ARFLAGS += --target=elf$(BITS)-$(GNUTARGET) |
14cf11af PM |
117 | endif |
118 | ||
c3ff2a51 | 119 | cflags-$(CONFIG_STACKPROTECTOR) += -mstack-protector-guard=tls |
06ec27ae CL |
120 | ifdef CONFIG_PPC64 |
121 | cflags-$(CONFIG_STACKPROTECTOR) += -mstack-protector-guard-reg=r13 | |
122 | else | |
c3ff2a51 | 123 | cflags-$(CONFIG_STACKPROTECTOR) += -mstack-protector-guard-reg=r2 |
06ec27ae | 124 | endif |
c3ff2a51 | 125 | |
9c5f7d39 SP |
126 | LDFLAGS_vmlinux-y := -Bstatic |
127 | LDFLAGS_vmlinux-$(CONFIG_RELOCATABLE) := -pie | |
128 | LDFLAGS_vmlinux := $(LDFLAGS_vmlinux-y) | |
83a092cf | 129 | LDFLAGS_vmlinux += $(call ld-option,--orphan-handling=warn) |
14cf11af | 130 | |
badf436f | 131 | ifdef CONFIG_PPC64 |
1fbe9cf2 AB |
132 | ifeq ($(call cc-option-yn,-mcmodel=medium),y) |
133 | # -mcmodel=medium breaks modules because it uses 32bit offsets from | |
134 | # the TOC pointer to create pointers where possible. Pointers into the | |
135 | # percpu data area are created by this method. | |
136 | # | |
137 | # The kernel module loader relocates the percpu data section from the | |
138 | # original location (starting with 0xd...) to somewhere in the base | |
139 | # kernel percpu data space (starting with 0xc...). We need a full | |
140 | # 64bit relocation for this to work, hence -mcmodel=large. | |
141 | KBUILD_CFLAGS_MODULE += -mcmodel=large | |
142 | else | |
143 | export NO_MINIMAL_TOC := -mno-minimal-toc | |
144 | endif | |
145 | endif | |
146 | ||
a50a862e | 147 | CFLAGS-$(CONFIG_PPC64) := $(call cc-option,-mtraceback=no) |
badf436f | 148 | ifdef CONFIG_CPU_LITTLE_ENDIAN |
238abecd | 149 | CFLAGS-$(CONFIG_PPC64) += $(call cc-option,-mabi=elfv2,$(call cc-option,-mcall-aixdesc)) |
721aeaa9 AB |
150 | AFLAGS-$(CONFIG_PPC64) += $(call cc-option,-mabi=elfv2) |
151 | else | |
4dc831aa | 152 | CFLAGS-$(CONFIG_PPC64) += $(call cc-option,-mabi=elfv1) |
238abecd | 153 | CFLAGS-$(CONFIG_PPC64) += $(call cc-option,-mcall-aixdesc) |
4dc831aa | 154 | AFLAGS-$(CONFIG_PPC64) += $(call cc-option,-mabi=elfv1) |
721aeaa9 | 155 | endif |
238abecd | 156 | CFLAGS-$(CONFIG_PPC64) += $(call cc-option,-mcmodel=medium,$(call cc-option,-mminimal-toc)) |
98679fb0 | 157 | CFLAGS-$(CONFIG_PPC64) += $(call cc-option,-mno-pointers-to-nested-functions) |
51d42f0f | 158 | |
72e7bcc2 JS |
159 | # Clang unconditionally reserves r2 on ppc32 and does not support the flag |
160 | # https://bugs.llvm.org/show_bug.cgi?id=39555 | |
161 | CFLAGS-$(CONFIG_PPC32) := $(call cc-option, -ffixed-r2) | |
162 | ||
163 | # Clang doesn't support -mmultiple / -mno-multiple | |
164 | # https://bugs.llvm.org/show_bug.cgi?id=39556 | |
165 | CFLAGS-$(CONFIG_PPC32) += $(call cc-option, $(MULTIPLEWORD)) | |
166 | ||
51d42f0f | 167 | CFLAGS-$(CONFIG_PPC32) += $(call cc-option,-mno-readonly-in-sdata) |
d23c6fb4 | 168 | |
badf436f RG |
169 | ifdef CONFIG_PPC_BOOK3S_64 |
170 | ifdef CONFIG_CPU_LITTLE_ENDIAN | |
a73657ea | 171 | CFLAGS-$(CONFIG_GENERIC_CPU) += -mcpu=power8 |
4b7e5532 | 172 | CFLAGS-$(CONFIG_GENERIC_CPU) += $(call cc-option,-mtune=power9,-mtune=power8) |
a73657ea | 173 | else |
471d7ff8 NP |
174 | CFLAGS-$(CONFIG_GENERIC_CPU) += $(call cc-option,-mtune=power7,$(call cc-option,-mtune=power5)) |
175 | CFLAGS-$(CONFIG_GENERIC_CPU) += $(call cc-option,-mcpu=power5,-mcpu=power4) | |
a73657ea | 176 | endif |
01718ba6 SW |
177 | else |
178 | CFLAGS-$(CONFIG_GENERIC_CPU) += -mcpu=powerpc64 | |
179 | endif | |
180 | ||
2a056f58 NP |
181 | ifdef CONFIG_FUNCTION_TRACER |
182 | CC_FLAGS_FTRACE := -pg | |
8c50b72a | 183 | ifdef CONFIG_MPROFILE_KERNEL |
2a056f58 NP |
184 | CC_FLAGS_FTRACE += -mprofile-kernel |
185 | endif | |
6977f95e NP |
186 | # Work around gcc code-gen bugs with -pg / -fno-omit-frame-pointer in gcc <= 4.8 |
187 | # https://gcc.gnu.org/bugzilla/show_bug.cgi?id=44199 | |
188 | # https://gcc.gnu.org/bugzilla/show_bug.cgi?id=52828 | |
076f421d | 189 | ifndef CONFIG_CC_IS_CLANG |
6977f95e NP |
190 | CC_FLAGS_FTRACE += $(call cc-ifversion, -lt, 0409, -mno-sched-epilog) |
191 | endif | |
8c50b72a TD |
192 | endif |
193 | ||
cc62d20c | 194 | CFLAGS-$(CONFIG_TARGET_CPU_BOOL) += $(call cc-option,-mcpu=$(CONFIG_TARGET_CPU)) |
d23c6fb4 | 195 | |
cbf8a358 | 196 | # Altivec option not allowed with e500mc64 in GCC. |
badf436f | 197 | ifdef CONFIG_ALTIVEC |
cbf8a358 TC |
198 | E5500_CPU := -mcpu=powerpc64 |
199 | else | |
01718ba6 | 200 | E5500_CPU := $(call cc-option,-mcpu=e500mc64,-mcpu=powerpc64) |
cbf8a358 | 201 | endif |
01718ba6 SW |
202 | CFLAGS-$(CONFIG_E5500_CPU) += $(E5500_CPU) |
203 | CFLAGS-$(CONFIG_E6500_CPU) += $(call cc-option,-mcpu=e6500,$(E5500_CPU)) | |
204 | ||
badf436f RG |
205 | ifdef CONFIG_PPC32 |
206 | ifdef CONFIG_PPC_E500MC | |
847f56b0 SW |
207 | CFLAGS-y += $(call cc-option,-mcpu=e500mc,-mcpu=powerpc) |
208 | else | |
209 | CFLAGS-$(CONFIG_E500) += $(call cc-option,-mcpu=8540 -msoft-float,-mcpu=powerpc) | |
210 | endif | |
211 | endif | |
212 | ||
7998eb3d GR |
213 | asinstr := $(call as-instr,lis 9$(comma)foo@high,-DHAVE_AS_ATHIGH=1) |
214 | ||
215 | KBUILD_CPPFLAGS += -Iarch/$(ARCH) $(asinstr) | |
58aedccb | 216 | KBUILD_AFLAGS += -Iarch/$(ARCH) $(AFLAGS-y) |
a50a862e AB |
217 | KBUILD_CFLAGS += $(call cc-option,-msoft-float) |
218 | KBUILD_CFLAGS += -pipe -Iarch/$(ARCH) $(CFLAGS-y) | |
a0f97e06 | 219 | CPP = $(CC) -E $(KBUILD_CFLAGS) |
14cf11af | 220 | |
68201fbb | 221 | CHECKFLAGS += -m$(BITS) -D__powerpc__ -D__powerpc$(BITS)__ |
62c2c5cf DA |
222 | ifdef CONFIG_CPU_BIG_ENDIAN |
223 | CHECKFLAGS += -D__BIG_ENDIAN__ | |
224 | else | |
225 | CHECKFLAGS += -D__LITTLE_ENDIAN__ | |
226 | endif | |
14cf11af | 227 | |
badf436f | 228 | ifdef CONFIG_476FPE_ERR46 |
d5b35cff AP |
229 | KBUILD_LDFLAGS_MODULE += --ppc476-workaround \ |
230 | -T $(srctree)/arch/powerpc/platforms/44x/ppc476_modules.lds | |
231 | endif | |
232 | ||
d23c6fb4 | 233 | # No AltiVec or VSX instructions when building kernel |
a0f97e06 | 234 | KBUILD_CFLAGS += $(call cc-option,-mno-altivec) |
d23c6fb4 | 235 | KBUILD_CFLAGS += $(call cc-option,-mno-vsx) |
d3f67fbb | 236 | |
0197cd2e | 237 | # No SPE instruction when building kernel |
ce400c01 | 238 | # (We use all available options to help semi-broken compilers) |
0197cd2e | 239 | KBUILD_CFLAGS += $(call cc-option,-mno-spe) |
ce400c01 | 240 | KBUILD_CFLAGS += $(call cc-option,-mspe=no) |
0197cd2e | 241 | |
d0679c73 AK |
242 | # FIXME: the module load should be taught about the additional relocs |
243 | # generated by this. | |
244 | # revert to pre-gcc-4.4 behaviour of .eh_frame | |
245 | KBUILD_CFLAGS += $(call cc-option,-fno-dwarf2-cfi-asm) | |
246 | ||
57647a4d BH |
247 | # Never use string load/store instructions as they are |
248 | # often slow when they are implemented at all | |
a50a862e | 249 | KBUILD_CFLAGS += $(call cc-option,-mno-string) |
14cf11af | 250 | |
14cf11af | 251 | cpu-as-$(CONFIG_4xx) += -Wa,-m405 |
9ddf0075 | 252 | cpu-as-$(CONFIG_ALTIVEC) += $(call as-option,-Wa$(comma)-maltivec) |
14cf11af | 253 | cpu-as-$(CONFIG_E200) += -Wa,-me200 |
4e4a4b75 | 254 | cpu-as-$(CONFIG_E500) += -Wa,-me500 |
960e3002 JS |
255 | |
256 | # When using '-many -mpower4' gas will first try and find a matching power4 | |
257 | # mnemonic and failing that it will allow any valid mnemonic that GAS knows | |
258 | # about. GCC will pass -many to GAS when assembling, clang does not. | |
259 | cpu-as-$(CONFIG_PPC_BOOK3S_64) += -Wa,-mpower4 -Wa,-many | |
69a84059 | 260 | cpu-as-$(CONFIG_PPC_E500MC) += $(call as-option,-Wa$(comma)-me500mc) |
14cf11af | 261 | |
222d394d | 262 | KBUILD_AFLAGS += $(cpu-as-y) |
a0f97e06 | 263 | KBUILD_CFLAGS += $(cpu-as-y) |
14cf11af | 264 | |
164af597 ME |
265 | KBUILD_AFLAGS += $(aflags-y) |
266 | KBUILD_CFLAGS += $(cflags-y) | |
267 | ||
68201fbb | 268 | head-y := arch/powerpc/kernel/head_$(BITS).o |
968159c0 | 269 | head-$(CONFIG_PPC_8xx) := arch/powerpc/kernel/head_8xx.o |
15f6527e | 270 | head-$(CONFIG_40x) := arch/powerpc/kernel/head_40x.o |
14cf11af PM |
271 | head-$(CONFIG_44x) := arch/powerpc/kernel/head_44x.o |
272 | head-$(CONFIG_FSL_BOOKE) := arch/powerpc/kernel/head_fsl_booke.o | |
273 | ||
9994a338 | 274 | head-$(CONFIG_PPC64) += arch/powerpc/kernel/entry_64.o |
14cf11af | 275 | head-$(CONFIG_PPC_FPU) += arch/powerpc/kernel/fpu.o |
e821ea70 | 276 | head-$(CONFIG_ALTIVEC) += arch/powerpc/kernel/vector.o |
5ac47f7a | 277 | head-$(CONFIG_PPC_OF_BOOT_TRAMPOLINE) += arch/powerpc/kernel/prom_init.o |
14cf11af | 278 | |
c47ca98d ME |
279 | # See arch/powerpc/Kbuild for content of core part of the kernel |
280 | core-y += arch/powerpc/ | |
14cf11af PM |
281 | |
282 | drivers-$(CONFIG_OPROFILE) += arch/powerpc/oprofile/ | |
283 | ||
135f0b17 | 284 | # Default to zImage, override when needed |
25431333 | 285 | all: zImage |
14cf11af | 286 | |
e32e78c5 | 287 | # With make 3.82 we cannot mix normal and wildcard targets |
c686ecf5 | 288 | BOOT_TARGETS1 := zImage zImage.initrd uImage |
11eab297 | 289 | BOOT_TARGETS2 := zImage% dtbImage% treeImage.% cuImage.% simpleImage.% uImage.% |
cabb5587 | 290 | |
e32e78c5 | 291 | PHONY += $(BOOT_TARGETS1) $(BOOT_TARGETS2) |
cabb5587 | 292 | |
94b212c2 | 293 | boot := arch/$(ARCH)/boot |
14cf11af | 294 | |
e32e78c5 | 295 | $(BOOT_TARGETS1): vmlinux |
1196d7aa | 296 | $(Q)$(MAKE) $(build)=$(boot) $(patsubst %,$(boot)/%,$@) |
e32e78c5 | 297 | $(BOOT_TARGETS2): vmlinux |
1196d7aa | 298 | $(Q)$(MAKE) $(build)=$(boot) $(patsubst %,$(boot)/%,$@) |
e32e78c5 SR |
299 | |
300 | ||
301 | bootwrapper_install: | |
1196d7aa | 302 | $(Q)$(MAKE) $(build)=$(boot) $(patsubst %,$(boot)/%,$@) |
773f76b1 | 303 | |
ea4d1a87 CB |
304 | # Used to create 'merged defconfigs' |
305 | # To use it $(call) it with the first argument as the base defconfig | |
306 | # and the second argument as a space separated list of .config files to merge, | |
307 | # without the .config suffix. | |
308 | define merge_into_defconfig | |
309 | $(Q)$(CONFIG_SHELL) $(srctree)/scripts/kconfig/merge_config.sh \ | |
310 | -m -O $(objtree) $(srctree)/arch/$(ARCH)/configs/$(1) \ | |
311 | $(foreach config,$(2),$(srctree)/arch/$(ARCH)/configs/$(config).config) | |
312 | +$(Q)$(MAKE) -f $(srctree)/Makefile olddefconfig | |
313 | endef | |
314 | ||
315 | PHONY += pseries_le_defconfig | |
316 | pseries_le_defconfig: | |
317 | $(call merge_into_defconfig,pseries_defconfig,le) | |
318 | ||
2adc48a6 ME |
319 | PHONY += ppc64le_defconfig |
320 | ppc64le_defconfig: | |
321 | $(call merge_into_defconfig,ppc64_defconfig,le) | |
322 | ||
721c01ba SR |
323 | PHONY += ppc64le_guest_defconfig |
324 | ppc64le_guest_defconfig: | |
325 | $(call merge_into_defconfig,ppc64_defconfig,le guest) | |
326 | ||
327 | PHONY += ppc64_guest_defconfig | |
328 | ppc64_guest_defconfig: | |
329 | $(call merge_into_defconfig,ppc64_defconfig,be guest) | |
330 | ||
3603c52f ME |
331 | PHONY += powernv_be_defconfig |
332 | powernv_be_defconfig: | |
333 | $(call merge_into_defconfig,powernv_defconfig,be) | |
334 | ||
44d54014 SW |
335 | PHONY += mpc85xx_defconfig |
336 | mpc85xx_defconfig: | |
337 | $(call merge_into_defconfig,mpc85xx_basic_defconfig,\ | |
338 | 85xx-32bit 85xx-hw fsl-emb-nonhw) | |
339 | ||
340 | PHONY += mpc85xx_smp_defconfig | |
341 | mpc85xx_smp_defconfig: | |
342 | $(call merge_into_defconfig,mpc85xx_basic_defconfig,\ | |
343 | 85xx-32bit 85xx-smp 85xx-hw fsl-emb-nonhw) | |
344 | ||
345 | PHONY += corenet32_smp_defconfig | |
346 | corenet32_smp_defconfig: | |
347 | $(call merge_into_defconfig,corenet_basic_defconfig,\ | |
e0b80f00 | 348 | 85xx-32bit 85xx-smp 85xx-hw fsl-emb-nonhw dpaa) |
44d54014 SW |
349 | |
350 | PHONY += corenet64_smp_defconfig | |
351 | corenet64_smp_defconfig: | |
352 | $(call merge_into_defconfig,corenet_basic_defconfig,\ | |
e0b80f00 | 353 | 85xx-64bit 85xx-smp altivec 85xx-hw fsl-emb-nonhw dpaa) |
44d54014 | 354 | |
43de32c5 AIB |
355 | PHONY += mpc86xx_defconfig |
356 | mpc86xx_defconfig: | |
357 | $(call merge_into_defconfig,mpc86xx_basic_defconfig,\ | |
358 | 86xx-hw fsl-emb-nonhw) | |
359 | ||
360 | PHONY += mpc86xx_smp_defconfig | |
361 | mpc86xx_smp_defconfig: | |
362 | $(call merge_into_defconfig,mpc86xx_basic_defconfig,\ | |
363 | 86xx-smp 86xx-hw fsl-emb-nonhw) | |
364 | ||
8db0c9d4 ME |
365 | PHONY += ppc32_allmodconfig |
366 | ppc32_allmodconfig: | |
367 | $(Q)$(MAKE) KCONFIG_ALLCONFIG=$(srctree)/arch/powerpc/configs/book3s_32.config \ | |
368 | -f $(srctree)/Makefile allmodconfig | |
369 | ||
64de5d8d ME |
370 | PHONY += ppc64le_allmodconfig |
371 | ppc64le_allmodconfig: | |
372 | $(Q)$(MAKE) KCONFIG_ALLCONFIG=$(srctree)/arch/powerpc/configs/le.config \ | |
373 | -f $(srctree)/Makefile allmodconfig | |
374 | ||
375 | PHONY += ppc64_book3e_allmodconfig | |
376 | ppc64_book3e_allmodconfig: | |
377 | $(Q)$(MAKE) KCONFIG_ALLCONFIG=$(srctree)/arch/powerpc/configs/85xx-64bit.config \ | |
378 | -f $(srctree)/Makefile allmodconfig | |
379 | ||
14cf11af | 380 | define archhelp |
70bf0333 GL |
381 | @echo '* zImage - Build default images selected by kernel config' |
382 | @echo ' zImage.* - Compressed kernel image (arch/$(ARCH)/boot/zImage.*)' | |
383 | @echo ' uImage - U-Boot native image format' | |
384 | @echo ' cuImage.<dt> - Backwards compatible U-Boot image for older' | |
385 | @echo ' versions which do not support device trees' | |
386 | @echo ' dtbImage.<dt> - zImage with an embedded device tree blob' | |
387 | @echo ' simpleImage.<dt> - Firmware independent image.' | |
388 | @echo ' treeImage.<dt> - Support for older IBM 4xx firmware (not U-Boot)' | |
14cf11af | 389 | @echo ' install - Install kernel using' |
caa27b66 SR |
390 | @echo ' (your) ~/bin/$(INSTALLKERNEL) or' |
391 | @echo ' (distribution) /sbin/$(INSTALLKERNEL) or' | |
14cf11af | 392 | @echo ' install to $$(INSTALL_PATH) and run lilo' |
437a58db | 393 | @echo ' *_defconfig - Select default config from arch/$(ARCH)/configs' |
70bf0333 GL |
394 | @echo '' |
395 | @echo ' Targets with <dt> embed a device tree blob inside the image' | |
396 | @echo ' These targets support board with firmware that does not' | |
397 | @echo ' support passing a device tree directly. Replace <dt> with the' | |
398 | @echo ' name of a dts file from the arch/$(ARCH)/boot/dts/ directory' | |
399 | @echo ' (minus the .dts extension).' | |
14cf11af PM |
400 | endef |
401 | ||
3f85d63e | 402 | install: |
25431333 | 403 | $(Q)$(MAKE) $(build)=$(boot) install |
928370c6 | 404 | |
8150caad | 405 | vdso_install: |
badf436f | 406 | ifdef CONFIG_PPC64 |
8150caad RM |
407 | $(Q)$(MAKE) $(build)=arch/$(ARCH)/kernel/vdso64 $@ |
408 | endif | |
409 | $(Q)$(MAKE) $(build)=arch/$(ARCH)/kernel/vdso32 $@ | |
410 | ||
14cf11af | 411 | archclean: |
a3a9e99e | 412 | $(Q)$(MAKE) $(clean)=$(boot) |
70567293 | 413 | |
14cf11af PM |
414 | archprepare: checkbin |
415 | ||
ab66dcc7 FK |
416 | archheaders: |
417 | $(Q)$(MAKE) $(build)=arch/powerpc/kernel/syscalls all | |
418 | ||
c3ff2a51 CL |
419 | ifdef CONFIG_STACKPROTECTOR |
420 | prepare: stack_protector_prepare | |
14cf11af | 421 | |
c3ff2a51 | 422 | stack_protector_prepare: prepare0 |
06ec27ae CL |
423 | ifdef CONFIG_PPC64 |
424 | $(eval KBUILD_CFLAGS += -mstack-protector-guard-offset=$(shell awk '{if ($$2 == "PACA_CANARY") print $$3;}' include/generated/asm-offsets.h)) | |
425 | else | |
c3ff2a51 CL |
426 | $(eval KBUILD_CFLAGS += -mstack-protector-guard-offset=$(shell awk '{if ($$2 == "TASK_CANARY") print $$3;}' include/generated/asm-offsets.h)) |
427 | endif | |
06ec27ae | 428 | endif |
c3ff2a51 | 429 | |
f2910f0e NP |
430 | # Check toolchain versions: |
431 | # - gcc-4.6 is the minimum kernel-wide version so nothing required. | |
14cf11af | 432 | checkbin: |
60e065f7 ME |
433 | @if test "x${CONFIG_CPU_LITTLE_ENDIAN}" = "xy" \ |
434 | && $(LD) --version | head -1 | grep ' 2\.24$$' >/dev/null ; then \ | |
435 | echo -n '*** binutils 2.24 miscompiles weak symbols ' ; \ | |
436 | echo 'in some circumstances.' ; \ | |
437 | echo -n '*** Please use a different binutils version.' ; \ | |
438 | false ; \ | |
439 | fi |