xref: /openbmc/linux/arch/powerpc/boot/Makefile (revision 1ac731c529cd4d6adbce134754b51ff7d822b145)
1b2441318SGreg Kroah-Hartman# SPDX-License-Identifier: GPL-2.0
294b212c2SPaul Mackerras# Makefile for making ELF bootable images for booting on CHRP
394b212c2SPaul Mackerras# using Open Firmware.
494b212c2SPaul Mackerras#
594b212c2SPaul Mackerras# Geert Uytterhoeven	September 1997
694b212c2SPaul Mackerras#
794b212c2SPaul Mackerras# Based on coffboot by Paul Mackerras
894b212c2SPaul Mackerras# Simplified for ppc64 by Todd Inglett
994b212c2SPaul Mackerras#
10364b236aSJordan Niethe# NOTE:	this code may be built for 32 bit in ELF32 format even though
1194b212c2SPaul Mackerras#	it packages a 64 bit kernel.  We do this to simplify the
1294b212c2SPaul Mackerras#	bootloader and increase compatibility with OpenFirmware.
1394b212c2SPaul Mackerras#
1494b212c2SPaul Mackerras#	To this end we need to define BOOTCC, etc, as the tools
15b610b978SDavid Gibson#	needed to build the 32 bit image.  That's normally the same
16b610b978SDavid Gibson#	compiler for the rest of the kernel, with the -m32 flag added.
1794b212c2SPaul Mackerras#	To make it easier to setup a cross compiler,
1894b212c2SPaul Mackerras#	CROSS32_COMPILE is setup as a prefix just like CROSS_COMPILE
1994b212c2SPaul Mackerras#	in the toplevel makefile.
2094b212c2SPaul Mackerras
212bf11819SPaul Mackerrasall: $(obj)/zImage
2294b212c2SPaul Mackerras
23af3901cbSNicholas Pigginifdef CROSS32_COMPILE
24215fadfeSBill Wendlingifdef CONFIG_CC_IS_CLANG
25215fadfeSBill Wendling    BOOTCC := $(CROSS32_COMPILE)clang
26215fadfeSBill Wendlingelse
27af3901cbSNicholas Piggin    BOOTCC := $(CROSS32_COMPILE)gcc
28215fadfeSBill Wendlingendif
29af3901cbSNicholas Piggin    BOOTAR := $(CROSS32_COMPILE)ar
30af3901cbSNicholas Pigginelse
31af3901cbSNicholas Piggin    BOOTCC := $(CC)
32af3901cbSNicholas Piggin    BOOTAR := $(AR)
33af3901cbSNicholas Pigginendif
34af3901cbSNicholas Piggin
35b610b978SDavid Gibsonifdef CONFIG_PPC64_BOOT_WRAPPER
36747b2176SJoel StanleyBOOTTARGETFLAGS	+= -m64
37110a58b9SPali RohárBOOTTARGETFLAGS	+= -mabi=elfv2
38e8e132e6SJoel Stanleyifdef CONFIG_PPC64_ELF_ABI_V2
394ba7f80fSMasahiro YamadaBOOTTARGETFLAGS	+= $(call cc-option,-mabi=elfv2)
4022750d98SOliver O'Halloranendif
41147c0516SCédric Le Goaterelse
42ff7c76f6SPali RohárBOOTTARGETFLAGS	:= -m32
43d1c5accaSNathan Chancellorendif
44d1c5accaSNathan Chancellor
45d1c5accaSNathan Chancellorifdef CONFIG_TARGET_CPU_BOOL
4665c5ec11SMichael EllermanBOOTTARGETFLAGS	+= -mcpu=$(CONFIG_TARGET_CPU)
47ff7c76f6SPali Rohárelse ifdef CONFIG_PPC64_BOOT_WRAPPER
4840a75584SJoel Stanleyifdef CONFIG_CPU_LITTLE_ENDIAN
49ff7c76f6SPali RohárBOOTTARGETFLAGS	+= -mcpu=powerpc64le
50ff7c76f6SPali Rohárelse
51ff7c76f6SPali RohárBOOTTARGETFLAGS	+= -mcpu=powerpc64
52ff7c76f6SPali Rohárendif
53ff7c76f6SPali Rohárendif
54ff7c76f6SPali Rohár
5540a75584SJoel Stanley$(obj)/4xx.o: BOOTTARGETFLAGS += -mcpu=405
56ff7c76f6SPali Rohár$(obj)/ebony.o: BOOTTARGETFLAGS += -mcpu=440
57ff7c76f6SPali Rohár$(obj)/cuboot-hotfoot.o: BOOTTARGETFLAGS += -mcpu=405
5865c5ec11SMichael Ellerman$(obj)/cuboot-taishan.o: BOOTTARGETFLAGS += -mcpu=440
5965c5ec11SMichael Ellerman$(obj)/cuboot-katmai.o: BOOTTARGETFLAGS += -mcpu=440
6065c5ec11SMichael Ellerman$(obj)/cuboot-acadia.o: BOOTTARGETFLAGS += -mcpu=405
6165c5ec11SMichael Ellerman$(obj)/treeboot-iss4xx.o: BOOTTARGETFLAGS += -mcpu=405
62147c0516SCédric Le Goater$(obj)/treeboot-currituck.o: BOOTTARGETFLAGS += -mcpu=405
63147c0516SCédric Le Goater$(obj)/treeboot-akebono.o: BOOTTARGETFLAGS += -mcpu=405
64655471f5SBenjamin Herrenschmidt
65655471f5SBenjamin Herrenschmidtifdef CONFIG_CPU_BIG_ENDIAN
66661aa880SChristophe LeroyBOOTTARGETFLAGS	+= -mbig-endian
67147c0516SCédric Le Goaterelse
684ba7f80fSMasahiro YamadaBOOTTARGETFLAGS	+= -mlittle-endian
6994b212c2SPaul Mackerrasendif
7013dc8c02SMasahiro Yamada
71af3901cbSNicholas PigginBOOTCPPFLAGS	:= -nostdinc $(LINUXINCLUDE)
72*2b694fc9SNathan ChancellorBOOTCPPFLAGS	+= -isystem $(shell $(BOOTCC) -print-file-name=include)
73*2b694fc9SNathan Chancellor
74*2b694fc9SNathan ChancellorBOOTCFLAGS	:= $(BOOTTARGETFLAGS) \
75*2b694fc9SNathan Chancellor		   -Wall -Wundef -Wstrict-prototypes -Wno-trigraphs \
76813af51fSJoel Stanley		   -fno-strict-aliasing -O2 \
77813af51fSJoel Stanley		   -msoft-float -mno-altivec -mno-vsx \
78813af51fSJoel Stanley		   $(call cc-option,-mno-prefixed) \
79813af51fSJoel Stanley		   $(call cc-option,-mno-pcrel) \
80813af51fSJoel Stanley		   $(call cc-option,-mno-mma) \
81105c13ddSGrant Likely		   $(call cc-option,-mno-spe) $(call cc-option,-mspe=no) \
82105c13ddSGrant Likely		   -fomit-frame-pointer -fno-builtin -fPIC
83105c13ddSGrant Likely
84105c13ddSGrant LikelyBOOTAFLAGS	:= $(BOOTTARGETFLAGS) -D__ASSEMBLY__
85fda7ffd2SNiels Kristian Bech Jensen
86fda7ffd2SNiels Kristian Bech JensenBOOTARFLAGS	:= -crD
87fda7ffd2SNiels Kristian Bech Jensen
88fda7ffd2SNiels Kristian Bech Jensenifdef CONFIG_CC_IS_CLANG
891619b69eSMichael EllermanBOOTCFLAGS += $(CLANG_FLAGS)
9058ab5e0cSArnd BergmannBOOTAFLAGS += $(CLANG_FLAGS)
9194b212c2SPaul Mackerrasendif
9263849340SDirk Brandewie
939d4ae9fcSKumar Galaifdef CONFIG_DEBUG_INFO
94bf2e70acSJosh BoyerBOOTCFLAGS	+= -g
95548ad77dSImre Kalozendif
960cdf50a7SSolomon Peachy
97548ad77dSImre Kalozifeq ($(call cc-option-yn, -fstack-protector),y)
98548ad77dSImre KalozBOOTCFLAGS	+= -fno-stack-protector
999f3eefc4SJosh Boyerendif
100b4e8c8ddSTorez Smith
101228d5505STony BreedsBOOTCFLAGS	+= -include $(srctree)/include/linux/compiler_attributes.h
1022a2c74b2SAlistair PoppleBOOTCFLAGS	+= -I$(objtree)/$(obj) -I$(srctree)/$(obj)
10360e41753SJosh Boyer
1041b7898eeSOliver O'HalloranDTC_FLAGS	?= -p 1024
1051b7898eeSOliver O'Halloran
1061b7898eeSOliver O'Halloran# The pre-boot decompressors pull in a lot of kernel headers and other source
1071b7898eeSOliver O'Halloran# files. This creates a bit of a dependency headache since we need to copy
1081b7898eeSOliver O'Halloran# these files into the build dir, fix up any includes and ensure that dependent
1091b7898eeSOliver O'Halloran# files are copied in the right order.
1101b7898eeSOliver O'Halloran
1111b7898eeSOliver O'Halloran# these need to be seperate variables because they are copied out of different
1121b7898eeSOliver O'Halloran# directories in the kernel tree. Sure you COULd merge them, but it's a
11322750d98SOliver O'Halloran# cure-is-worse-than-disease situation.
11422750d98SOliver O'Halloranzlib-decomp-$(CONFIG_KERNEL_GZIP) := decompress_inflate.c
11522750d98SOliver O'Halloranzlib-$(CONFIG_KERNEL_GZIP) := inffast.c inflate.c inftrees.c
1166bbc5476SHugh Blemingszlibheader-$(CONFIG_KERNEL_GZIP) := inffast.h inffixed.h inflate.h inftrees.h infutil.h
1171b7898eeSOliver O'Halloranzliblinuxheader-$(CONFIG_KERNEL_GZIP) := zlib.h zconf.h zutil.h
1181b7898eeSOliver O'Halloran
1191b7898eeSOliver O'Halloran$(addprefix $(obj)/, decompress.o): \
1201b7898eeSOliver O'Halloran	$(addprefix $(obj)/,$(zlib-decomp-y))
1211b7898eeSOliver O'Halloran
1221b7898eeSOliver O'Halloran$(addprefix $(obj)/, $(zlib-decomp-y)): \
1231b7898eeSOliver O'Halloran	$(addprefix $(obj)/,$(zliblinuxheader-y)) \
1241b7898eeSOliver O'Halloran	$(addprefix $(obj)/,$(zlibheader-y)) \
1251b7898eeSOliver O'Halloran	$(addprefix $(obj)/,$(zlib-y))
12622750d98SOliver O'Halloran
12722750d98SOliver O'Halloran$(addprefix $(obj)/,$(zlib-y)): \
1282bf11819SPaul Mackerras	$(addprefix $(obj)/,$(zliblinuxheader-y)) \
1299fffb55fSDavid Gibson	$(addprefix $(obj)/,$(zlibheader-y))
1309fffb55fSDavid Gibson
1319fffb55fSDavid Gibsonlibfdt       := fdt.c fdt_ro.c fdt_wip.c fdt_sw.c fdt_rw.c fdt_strerror.c
13264c3f648SGuenter Roecklibfdtheader := fdt.h libfdt.h libfdt_internal.h
13364c3f648SGuenter Roeck
1349fffb55fSDavid Gibson$(addprefix $(obj)/,$(libfdt) libfdt-wrapper.o simpleboot.o epapr.o opal.o \
1359fffb55fSDavid Gibson	treeboot-akebono.o treeboot-currituck.o treeboot-iss4xx.o): \
1367c868b66SNicholas Piggin	$(addprefix $(obj)/,$(libfdtheader))
1379fffb55fSDavid Gibson
138ad9d2716SDavid Gibsonsrc-wlib-y := string.S crt0.S stdio.c decompress.c main.c \
1391b7898eeSOliver O'Halloran		$(libfdt) libfdt-wrapper.c \
140c3bb690dSMichael Ellerman		ns16550.c serial.c simple_alloc.c div64.S util.S \
141f8e8e69cSMichael Ellerman		elf_util.c $(zlib-y) devtree.c stdlib.c \
142e5eff896SMichael Ellerman		oflib.c ofconsole.c cuboot.c
1436ffeb56eSCédric Le Goater
1447c868b66SNicholas Pigginsrc-wlib-$(CONFIG_PPC_MPC52xx) += mpc52xx-psc.c
1457c868b66SNicholas Pigginsrc-wlib-$(CONFIG_PPC_POWERNV) += opal-calls.S opal.c
1467c868b66SNicholas Pigginifndef CONFIG_PPC64_BOOT_WRAPPER
147b81f18e5STony Breedssrc-wlib-y += crtsavres.S
148b81f18e5STony Breedsendif
149968159c0SChristophe Leroysrc-wlib-$(CONFIG_40x) += 4xx.c planetcore.c
150b81f18e5STony Breedssrc-wlib-$(CONFIG_44x) += 4xx.c ebony.c bamboo.c
151297f8314SMark Greersrc-wlib-$(CONFIG_PPC_8xx) += mpc8xx.c planetcore.c fsl-soc.c
152c3bb690dSMichael Ellermansrc-wlib-$(CONFIG_PPC_82xx) += pq2.c fsl-soc.c planetcore.c
153b81f18e5STony Breedssrc-wlib-$(CONFIG_EMBEDDED6xx) += ugecon.c fsl-soc.c
1540c9fa291SBenjamin Herrenschmidtsrc-wlib-$(CONFIG_CPM) += cpm-serial.c
155548f5244SChristophe Leroy
1565786074bSChristophe Leroysrc-plat-y := of.c epapr.c
1577ade8495SMichal Simeksrc-plat-$(CONFIG_40x) += fixed-head.S cuboot-hotfoot.c \
158b81f18e5STony Breeds				cuboot-acadia.c \
159b81f18e5STony Breeds				cuboot-kilauea.c simpleboot.c
160b81f18e5STony Breedssrc-plat-$(CONFIG_44x) += treeboot-ebony.c cuboot-ebony.c treeboot-bamboo.c \
161b81f18e5STony Breeds				cuboot-bamboo.c cuboot-sam440ep.c \
162b81f18e5STony Breeds				cuboot-sequoia.c cuboot-rainier.c \
163b81f18e5STony Breeds				cuboot-taishan.c cuboot-katmai.c \
1642a2c74b2SAlistair Popple				cuboot-warp.c cuboot-yosemite.c \
1657ade8495SMichal Simek				treeboot-iss4xx.c treeboot-currituck.c \
166968159c0SChristophe Leroy				treeboot-akebono.c \
167b81f18e5STony Breeds				simpleboot.c fixed-head.S
168b81f18e5STony Breedssrc-plat-$(CONFIG_PPC_8xx) += cuboot-8xx.c fixed-head.S ep88xc.c redboot-8xx.c
169b81f18e5STony Breedssrc-plat-$(CONFIG_PPC_MPC52xx) += cuboot-52xx.c
170b81f18e5STony Breedssrc-plat-$(CONFIG_PPC_82xx) += cuboot-pq2.c fixed-head.S ep8248e.c cuboot-824x.c
171f03425a5SPaul Gortmakersrc-plat-$(CONFIG_PPC_83xx) += cuboot-83xx.c fixed-head.S redboot-83xx.c
17292c8c16fSMark Greersrc-plat-$(CONFIG_FSL_SOC_BOOKE) += cuboot-85xx.c cuboot-85xx-cpm2.c
17392c8c16fSMark Greersrc-plat-$(CONFIG_EMBEDDED6xx) += cuboot-pq2.c \
1743c8464a9SPaul Gortmaker					gamecube-head.S gamecube.c \
175b81f18e5STony Breeds					wii-head.S wii.c holly.c \
176b81f18e5STony Breeds					fixed-head.S mvme5100.c
1770c9fa291SBenjamin Herrenschmidtsrc-plat-$(CONFIG_AMIGAONE) += cuboot-amigaone.c
1782d9afb36SCédric Le Goatersrc-plat-$(CONFIG_PPC_PS3) += ps3-head.S ps3-hvcall.S ps3.c
1792d9afb36SCédric Le Goatersrc-plat-$(CONFIG_EPAPR_BOOT) += epapr.c epapr-wrapper.c
1802d9afb36SCédric Le Goatersrc-plat-$(CONFIG_PPC_PSERIES) += pseries-head.S
18197493e2eSAlessio Igor Boganisrc-plat-$(CONFIG_PPC_POWERNV) += pseries-head.S
182b81f18e5STony Breedssrc-plat-$(CONFIG_PPC_IBM_CELL_BLADE) += pseries-head.S
1834a21192eSJoel Stanleysrc-plat-$(CONFIG_MVME7100) += motload-head.S mvme7100.c
1844a21192eSJoel Stanley
185b81f18e5STony Breedssrc-plat-$(CONFIG_PPC_MICROWATT) += fixed-head.S microwatt.c
186b81f18e5STony Breeds
187cd197ffcSDavid Gibsonsrc-wlib := $(sort $(src-wlib-y))
1882bf11819SPaul Mackerrassrc-plat := $(sort $(src-plat-y))
1892bf11819SPaul Mackerrassrc-boot := $(src-wlib) $(src-plat) empty.c
1902bf11819SPaul Mackerras
1912bf11819SPaul Mackerrassrc-boot := $(addprefix $(obj)/, $(src-boot))
1922bf11819SPaul Mackerrasobj-boot := $(addsuffix .o, $(basename $(src-boot)))
1930090e02bSMatthew McClintockobj-wlib := $(addsuffix .o, $(basename $(addprefix $(obj)/, $(src-wlib))))
1942bf11819SPaul Mackerrasobj-plat := $(addsuffix .o, $(basename $(addprefix $(obj)/, $(src-plat))))
1951a13de6dSOliver O'Halloranobj-plat: $(libfdt)
1961a13de6dSOliver O'Halloran
19794b212c2SPaul Mackerrasquiet_cmd_copy_kern_src = COPY    $@
19822750d98SOliver O'Halloran      cmd_copy_kern_src = sed -f $(srctree)/arch/powerpc/boot/fixup-headers.sed $< > $@
1991a13de6dSOliver O'Halloran
20094b212c2SPaul Mackerras$(addprefix $(obj)/,$(zlib-y)): $(obj)/%: $(srctree)/lib/zlib_inflate/%
20122750d98SOliver O'Halloran	$(call cmd,copy_kern_src)
2021a13de6dSOliver O'Halloran
20394b212c2SPaul Mackerras$(addprefix $(obj)/,$(zlibheader-y)): $(obj)/%: $(srctree)/lib/zlib_inflate/%
20422750d98SOliver O'Halloran	$(call cmd,copy_kern_src)
2051a13de6dSOliver O'Halloran
20694b212c2SPaul Mackerras$(addprefix $(obj)/,$(zliblinuxheader-y)): $(obj)/%: $(srctree)/include/linux/%
2071b7898eeSOliver O'Halloran	$(call cmd,copy_kern_src)
2081b7898eeSOliver O'Halloran
2091b7898eeSOliver O'Halloran$(addprefix $(obj)/,$(zlib-decomp-y)): $(obj)/%: $(srctree)/lib/%
2109fffb55fSDavid Gibson	$(call cmd,copy_kern_src)
2119fffb55fSDavid Gibson
2129fffb55fSDavid Gibsonquiet_cmd_copy_libfdt = COPY    $@
2139fffb55fSDavid Gibson      cmd_copy_libfdt = cp $< $@
2149fffb55fSDavid Gibson
2159fffb55fSDavid Gibson$(addprefix $(obj)/,$(libfdt) $(libfdtheader)): $(obj)/%: $(srctree)/scripts/dtc/libfdt/%
2162bf11819SPaul Mackerras	$(call cmd,copy_libfdt)
2176abe248eSMichael Ellerman
21894b212c2SPaul Mackerras$(obj)/empty.c:
219147c0516SCédric Le Goater	$(Q)touch $@
2206abe248eSMichael Ellerman
2212bf11819SPaul Mackerras$(obj)/zImage.coff.lds $(obj)/zImage.ps3.lds : $(obj)/%: $(srctree)/$(src)/%.S
22222750d98SOliver O'Halloran	$(Q)cp $< $@
2231b7898eeSOliver O'Halloran
2244ba7f80fSMasahiro Yamadaclean-files := $(zlib-) $(zlibheader-) $(zliblinuxheader-) \
22594b212c2SPaul Mackerras		$(zlib-decomp-) $(libfdt) $(libfdtheader) \
22694b212c2SPaul Mackerras		empty.c zImage.coff.lds zImage.ps3.lds zImage.lds
22765c5ec11SMichael Ellerman
22894b212c2SPaul Mackerrasquiet_cmd_bootcc = BOOTCC  $@
22994b212c2SPaul Mackerras      cmd_bootcc = $(BOOTCC) -Wp,-MD,$(depfile) $(BOOTCPPFLAGS) $(BOOTCFLAGS) -c -o $@ $<
23065c5ec11SMichael Ellerman
23194b212c2SPaul Mackerrasquiet_cmd_bootas = BOOTAS  $@
2322bf11819SPaul Mackerras      cmd_bootas = $(BOOTCC) -Wp,-MD,$(depfile) $(BOOTCPPFLAGS) $(BOOTAFLAGS) -c -o $@ $<
233afa974b7SMasahiro Yamada
23494b212c2SPaul Mackerrasquiet_cmd_bootar = BOOTAR  $@
2359fffb55fSDavid Gibson      cmd_bootar = $(BOOTAR) $(BOOTARFLAGS) $@.$$$$ $(real-prereqs); mv $@.$$$$ $@
2369fffb55fSDavid Gibson
237235fd835SMilton Miller$(obj-libfdt): $(obj)/%.o: $(srctree)/scripts/dtc/libfdt/%.c FORCE
2382f0dfeaaSDavid Gibson	$(call if_changed_dep,bootcc)
23994b212c2SPaul Mackerras$(patsubst %.c,%.o, $(filter %.c, $(src-boot))): %.o: %.c FORCE
240235fd835SMilton Miller	$(Q)mkdir -p $(dir $@)
2412f0dfeaaSDavid Gibson	$(call if_changed_dep,bootcc)
24294b212c2SPaul Mackerras$(patsubst %.S,%.o, $(filter %.S, $(src-boot))): %.o: %.S FORCE
24394b212c2SPaul Mackerras	$(Q)mkdir -p $(dir $@)
244235fd835SMilton Miller	$(call if_changed_dep,bootas)
245235fd835SMilton Miller
24694b212c2SPaul Mackerras$(obj)/wrapper.a: $(obj-wlib) FORCE
2475f2fb52fSMasahiro Yamada	$(call if_changed,bootar)
24866a45dd3SPaul Mackerras
249710e6822SNicholas Pigginhostprogs	:= addnote hack-coff mktree
250cd197ffcSDavid Gibson
251bafdb645SGeoff Levandtargets		+= $(patsubst $(obj)/%,%,$(obj-boot) wrapper.a) zImage.lds
25294b212c2SPaul Mackerrasextra-y		:= $(obj)/wrapper.a $(obj-plat) $(obj)/empty.o \
25325431333SGrant Likely		   $(obj)/zImage.lds $(obj)/zImage.coff.lds $(obj)/zImage.ps3.lds
25425431333SGrant Likely
2552bf11819SPaul Mackerrasdtstree		:= $(srctree)/$(src)/dts
2569fffb55fSDavid Gibson
257235fd835SMilton Millerwrapper		:=$(srctree)/$(src)/wrapper
25894b212c2SPaul Mackerraswrapperbits	:= $(extra-y) $(addprefix $(obj)/,addnote hack-coff mktree) \
2592bf11819SPaul Mackerras			$(wrapper) FORCE
2602bf11819SPaul Mackerras
26194b212c2SPaul Mackerras#############
2622bf11819SPaul Mackerras# Bits for building various flavours of zImage
263dcf90651SMichael Ellerman
2642bf11819SPaul Mackerrasifneq ($(CROSS32_COMPILE),)
2652bf11819SPaul MackerrasCROSSWRAP := -C "$(CROSS32_COMPILE)"
266dcf90651SMichael Ellermanelse
2672bf11819SPaul Mackerrasifneq ($(CROSS_COMPILE),)
2682bf11819SPaul MackerrasCROSSWRAP := -C "$(CROSS_COMPILE)"
26994b212c2SPaul Mackerrasendif
270f1e510bbSOliver O'Halloranendif
271c762c69eSOliver O'Halloran
2721cc9a21bSChristophe Leroycompressor-$(CONFIG_KERNEL_GZIP) := gz
273264bffadSChristophe Leroycompressor-$(CONFIG_KERNEL_XZ)   := xz
274f1e510bbSOliver O'Hallorancompressor-$(CONFIG_KERNEL_LZMA)   := lzma
2759da82a6dSMilton Millercompressor-$(CONFIG_KERNEL_LZO) := lzo
2762bf11819SPaul Mackerras
277f1e510bbSOliver O'Halloran# args (to if_changed): 1 = (this rule), 2 = platform, 3 = dts 4=dtb 5=initrd
278f1e510bbSOliver O'Halloranquiet_cmd_wrap	= WRAP    $@
279f1e510bbSOliver O'Halloran      cmd_wrap	=$(CONFIG_SHELL) $(wrapper) -Z $(compressor-y) -c -o $@ -p $2 \
2802bf11819SPaul Mackerras		$(CROSSWRAP) $(if $3, -s $3)$(if $4, -d $4)$(if $5, -i $5) \
2812bf11819SPaul Mackerras		vmlinux
28255190f88SBenjamin Herrenschmidt
28358706ef9SCorey Minyardimage-$(CONFIG_PPC_PSERIES)		+= zImage.pseries
284020533efSGeoff Levandimage-$(CONFIG_PPC_POWERNV)		+= zImage.pseries
285595be948SGrant Likelyimage-$(CONFIG_PPC_MAPLE)		+= zImage.maple
2862bf11819SPaul Mackerrasimage-$(CONFIG_PPC_IBM_CELL_BLADE)	+= zImage.pseries
2877839af33SNicolas DETimage-$(CONFIG_PPC_PS3)			+= dtbImage.ps3
2882bf11819SPaul Mackerrasimage-$(CONFIG_PPC_CHRP)		+= zImage.chrp
28932dde0f9SJosh Boyerimage-$(CONFIG_PPC_EFIKA)		+= zImage.chrp
290ac18c673SScott Woodimage-$(CONFIG_PPC_PMAC)		+= zImage.pmac
2916c5b59b9SDavid Gibsonimage-$(CONFIG_PPC_HOLLY)		+= dtbImage.holly
292ac18c673SScott Woodimage-$(CONFIG_DEFAULT_UIMAGE)		+= uImage
29325431333SGrant Likelyimage-$(CONFIG_EPAPR_BOOT)		+= zImage.epapr
29425431333SGrant Likely
29525431333SGrant Likely#
29625431333SGrant Likely# Targets which embed a device tree blob
29725431333SGrant Likely#
2982a94739cSNick Andrew# Theses are default targets to build images which embed device tree blobs.
29925431333SGrant Likely# They are only required on boards which do not have FDT support in firmware.
30025431333SGrant Likely# Boards with newish u-boot firmware can use the uImage target above
30125431333SGrant Likely#
3020cdf50a7SSolomon Peachy
30394c73a8fSJosh Boyer# Board ports in arch/powerpc/platform/40x/Kconfig
30411eab297SBenjamin Herrenschmidtimage-$(CONFIG_HOTFOOT)			+= cuImage.hotfoot
30525431333SGrant Likelyimage-$(CONFIG_ACADIA)			+= cuImage.acadia
30625431333SGrant Likelyimage-$(CONFIG_OBS600)			+= uImage.obs600
307f6dfc805SDavid Gibson
308658e8170SJosh Boyer# Board ports in arch/powerpc/platform/44x/Kconfig
309b6014e15SGiuseppe Covielloimage-$(CONFIG_EBONY)			+= treeImage.ebony cuImage.ebony
310606d08bcSValentine Barshakimage-$(CONFIG_BAMBOO)			+= treeImage.bamboo cuImage.bamboo
311295e7427SValentine Barshakimage-$(CONFIG_SAM440EP)		+= cuImage.sam440ep
3126bbc5476SHugh Blemingsimage-$(CONFIG_SEQUOIA)			+= cuImage.sequoia
3133de9c9cdSBenjamin Herrenschmidtimage-$(CONFIG_RAINIER)			+= cuImage.rainier
3141e12f3c5SSean MacLennanimage-$(CONFIG_TAISHAN)			+= cuImage.taishan
315d0a48c9fSJosh Boyerimage-$(CONFIG_KATMAI)			+= cuImage.katmai
316b4e8c8ddSTorez Smithimage-$(CONFIG_WARP)			+= cuImage.warp
317b4e8c8ddSTorez Smithimage-$(CONFIG_YOSEMITE)		+= cuImage.yosemite
318228d5505STony Breedsimage-$(CONFIG_ISS4xx)			+= treeImage.iss4xx \
3192a2c74b2SAlistair Popple					   treeImage.iss4xx-mpic
32094b212c2SPaul Mackerrasimage-$(CONFIG_CURRITUCK)			+= treeImage.currituck
32125431333SGrant Likelyimage-$(CONFIG_AKEBONO)			+= treeImage.akebono
322efa58fbfSAdrian Bunk
323efa58fbfSAdrian Bunk# Board ports in arch/powerpc/platform/8xx/Kconfig
324595be948SGrant Likelyimage-$(CONFIG_MPC86XADS)		+= cuImage.mpc866ads
32525431333SGrant Likelyimage-$(CONFIG_MPC885ADS)		+= cuImage.mpc885ads
326595be948SGrant Likelyimage-$(CONFIG_PPC_EP88XC)		+= dtbImage.ep88xc
32725431333SGrant Likelyimage-$(CONFIG_PPC_ADDER875)		+= cuImage.adder875-uboot \
32825431333SGrant Likely					   dtbImage.adder875-redboot
3291acf1cf8SRob Herring
3301acf1cf8SRob Herring# Board ports in arch/powerpc/platform/52xx/Kconfig
3311acf1cf8SRob Herringimage-$(CONFIG_PPC_LITE5200)		+= cuImage.lite5200
33225431333SGrant Likelyimage-$(CONFIG_PPC_LITE5200)		+= cuImage.lite5200b
33325431333SGrant Likelyimage-$(CONFIG_PPC_MEDIA5200)		+= cuImage.media5200
334595be948SGrant Likely
33525431333SGrant Likely# Board ports in arch/powerpc/platform/82xx/Kconfig
33625431333SGrant Likelyimage-$(CONFIG_EP8248E)			+= dtbImage.ep8248e
33725431333SGrant Likely
33825431333SGrant Likely# Board ports in arch/powerpc/platform/83xx/Kconfig
33925431333SGrant Likelyimage-$(CONFIG_MPC832x_RDB)		+= cuImage.mpc832x_rdb
34059d13f9dSBryan O'Donoghueimage-$(CONFIG_MPC834x_ITX)		+= cuImage.mpc8349emitx \
34125431333SGrant Likely					   cuImage.mpc8349emitxgp
34225431333SGrant Likelyimage-$(CONFIG_ASP834x)			+= dtbImage.asp834x-redboot
34325431333SGrant Likely
34425431333SGrant Likely# Board ports in arch/powerpc/platform/85xx/Kconfig
34525431333SGrant Likelyimage-$(CONFIG_MPC85xx_MDS)		+= cuImage.mpc8568mds
3460d4fdd32SZhao Chenhuiimage-$(CONFIG_MPC85xx_DS)		+= cuImage.mpc8544ds \
34725431333SGrant Likely					   cuImage.mpc8572ds
34825431333SGrant Likelyimage-$(CONFIG_TQM8540)			+= cuImage.tqm8540
34925431333SGrant Likelyimage-$(CONFIG_TQM8541)			+= cuImage.tqm8541
35025431333SGrant Likelyimage-$(CONFIG_TQM8548)			+= cuImage.tqm8548
35125431333SGrant Likelyimage-$(CONFIG_TQM8555)			+= cuImage.tqm8555
35225431333SGrant Likelyimage-$(CONFIG_TQM8560)			+= cuImage.tqm8560
3536dd1b64aSWolfgang Grandeggerimage-$(CONFIG_KSI8560)			+= cuImage.ksi8560
35425431333SGrant Likely
35525431333SGrant Likely# Board ports in arch/powerpc/platform/86xx/Kconfig
356ff880112SAlexandr Smirnovimage-$(CONFIG_MVME7100)                += dtbImage.mvme7100
35725431333SGrant Likely
35897493e2eSAlessio Igor Bogani# Board ports in arch/powerpc/platform/embedded6xx/Kconfig
35997493e2eSAlessio Igor Boganiimage-$(CONFIG_STORCENTER)		+= cuImage.storcenter
36097493e2eSAlessio Igor Boganiimage-$(CONFIG_GAMECUBE)		+= dtbImage.gamecube
36125431333SGrant Likelyimage-$(CONFIG_WII)			+= dtbImage.wii
36225431333SGrant Likelyimage-$(CONFIG_MVME5100)		+= dtbImage.mvme5100
363b68a24bcSAlbert Herranz
3646cdd2417SAlbert Herranz# Board port in arch/powerpc/platform/amigaone/Kconfig
365be201981SStephen Chiversimage-$(CONFIG_AMIGAONE)		+= cuImage.amigaone
366b09c1644SScott Wood
3678f23735dSGerhard Pircherimage-$(CONFIG_PPC_MICROWATT)		+= dtbImage.microwatt
3688f23735dSGerhard Pircher
3698f23735dSGerhard Pircher# For 32-bit powermacs, build the COFF and miboot images
3704a21192eSJoel Stanley# as well as the ELF images.
3714a21192eSJoel Stanleyifdef CONFIG_PPC32
3729216ad8cSPaul Mackerrasimage-$(CONFIG_PPC_PMAC)	+= zImage.coff zImage.miboot
3739216ad8cSPaul Mackerrasendif
374badf436fSRodrigo R. Galvao
3752bf11819SPaul Mackerras# Allow extra targets to be added to the defconfig
3762bf11819SPaul Mackerrasimage-y	+= $(CONFIG_EXTRA_TARGETS)
37766a45dd3SPaul Mackerras
378c356aa45SGrant Likelyinitrd-  := $(patsubst zImage%, zImage.initrd%, $(image-))
379129ab0d2SMasahiro Yamadainitrd-y := $(patsubst zImage%, zImage.initrd%, \
380c356aa45SGrant Likely		$(patsubst dtbImage%, dtbImage.initrd%, \
381755457f9SMichal Marek		$(patsubst simpleImage%, simpleImage.initrd%, \
382f6dfc805SDavid Gibson		$(patsubst treeImage%, treeImage.initrd%, $(image-y)))))
383595be948SGrant Likelyinitrd-y := $(filter-out $(image-y), $(initrd-y))
3845d1a0411SJohn Linntargets	+= $(image-y) $(initrd-y)
3855d1a0411SJohn Linntargets += $(foreach x, dtbImage uImage cuImage simpleImage treeImage, \
3869da82a6dSMilton Miller		$(patsubst $(x).%, dts/%.dtb, $(filter $(x).%, $(image-y))))
387235fd835SMilton Millertargets += $(foreach x, dtbImage uImage cuImage simpleImage treeImage, \
3881bca5440SMasahiro Yamada		$(patsubst $(x).%, dts/fsl/%.dtb, $(filter $(x).%, $(image-y))))
3891bca5440SMasahiro Yamada
390b36f835bSMichael Ellerman$(addprefix $(obj)/, $(initrd-y)): $(obj)/ramdisk.image.gz
391b36f835bSMichael Ellerman
39294b212c2SPaul Mackerras# Don't put the ramdisk on the pattern rule; when its missing make will try
3939da82a6dSMilton Miller# the pattern rule with less dependencies that also matches (even with the
3949da82a6dSMilton Miller# hard dependency listed).
3959da82a6dSMilton Miller$(obj)/zImage.initrd.%: vmlinux $(wrapperbits) FORCE
3969da82a6dSMilton Miller	$(call if_changed,wrap,$*,,,$(obj)/ramdisk.image.gz)
3979da82a6dSMilton Miller
39842d0c932SMichael Ellerman$(addprefix $(obj)/, $(sort $(filter zImage.%, $(image-y)))): vmlinux $(wrapperbits) FORCE
39925431333SGrant Likely	$(call if_changed,wrap,$(subst $(obj)/zImage.,,$@))
4009da82a6dSMilton Miller
40142d0c932SMichael Ellerman# dtbImage% - a dtbImage is a zImage with an embedded device tree blob
402699c659bSMichal Marek$(obj)/dtbImage.initrd.%: vmlinux $(wrapperbits) $(obj)/dts/%.dtb FORCE
40325431333SGrant Likely	$(call if_changed,wrap,$*,,$(obj)/dts/$*.dtb,$(obj)/ramdisk.image.gz)
404595be948SGrant Likely
4051acf1cf8SRob Herring$(obj)/dtbImage.%: vmlinux $(wrapperbits) $(obj)/dts/%.dtb FORCE
4061acf1cf8SRob Herring	$(call if_changed,wrap,$*,,$(obj)/dts/$*.dtb)
40725431333SGrant Likely
4081acf1cf8SRob Herring# This cannot be in the root of $(src) as the zImage rule always adds a $(obj)
4091acf1cf8SRob Herring# prefix
4109da82a6dSMilton Miller$(obj)/vmlinux.strip: vmlinux
4114bb09281STony Breeds	$(STRIP) -s -R .comment $< -o $@
4124bb09281STony Breeds
4134bb09281STony Breeds$(obj)/uImage: vmlinux $(wrapperbits) FORCE
4144bb09281STony Breeds	$(call if_changed,wrap,uboot)
4154bb09281STony Breeds
41642d0c932SMichael Ellerman$(obj)/uImage.initrd.%: vmlinux $(obj)/dts/%.dtb $(wrapperbits) FORCE
4179da82a6dSMilton Miller	$(call if_changed,wrap,uboot-$*,,$(obj)/dts/$*.dtb,$(obj)/ramdisk.image.gz)
4189da82a6dSMilton Miller
4191acf1cf8SRob Herring$(obj)/uImage.%: vmlinux $(obj)/dts/%.dtb $(wrapperbits) FORCE
4201acf1cf8SRob Herring	$(call if_changed,wrap,uboot-$*,,$(obj)/dts/$*.dtb)
42111eab297SBenjamin Herrenschmidt
4221acf1cf8SRob Herring$(obj)/cuImage.initrd.%: vmlinux $(obj)/dts/%.dtb $(wrapperbits) FORCE
4231acf1cf8SRob Herring	$(call if_changed,wrap,cuboot-$*,,$(obj)/dts/$*.dtb,$(obj)/ramdisk.image.gz)
42411eab297SBenjamin Herrenschmidt
4251acf1cf8SRob Herring$(obj)/cuImage.%: vmlinux $(obj)/dts/%.dtb $(wrapperbits) FORCE
4261acf1cf8SRob Herring	$(call if_changed,wrap,cuboot-$*,,$(obj)/dts/$*.dtb)
427a4292d7aSGrant Likely
4281acf1cf8SRob Herring$(obj)/simpleImage.initrd.%: vmlinux $(obj)/dts/%.dtb $(wrapperbits) FORCE
4291acf1cf8SRob Herring	$(call if_changed,wrap,simpleboot-$*,,$(obj)/dts/$*.dtb,$(obj)/ramdisk.image.gz)
4300fdd717eSScott Wood
4311acf1cf8SRob Herring$(obj)/simpleImage.%: vmlinux $(obj)/dts/%.dtb $(wrapperbits) FORCE
4321acf1cf8SRob Herring	$(call if_changed,wrap,simpleboot-$*,,$(obj)/dts/$*.dtb)
433d2477b5cSGrant Likely
4341acf1cf8SRob Herring$(obj)/treeImage.initrd.%: vmlinux $(obj)/dts/%.dtb $(wrapperbits) FORCE
4351acf1cf8SRob Herring	$(call if_changed,wrap,treeboot-$*,,$(obj)/dts/$*.dtb,$(obj)/ramdisk.image.gz)
436d2477b5cSGrant Likely
4371acf1cf8SRob Herring$(obj)/treeImage.%: vmlinux $(obj)/dts/%.dtb $(wrapperbits) FORCE
4381acf1cf8SRob Herring	$(call if_changed,wrap,treeboot-$*,,$(obj)/dts/$*.dtb)
439f6dfc805SDavid Gibson
4401acf1cf8SRob Herring# Needed for the above targets to work with dts/fsl/ files
4411acf1cf8SRob Herring$(obj)/dts/%.dtb: $(obj)/dts/fsl/%.dtb
442e04018e8SGrant Likely	@cp $< $@
4431acf1cf8SRob Herring
4441acf1cf8SRob Herring# If there isn't a platform selected then just strip the vmlinux.
4451acf1cf8SRob Herringifeq (,$(image-y))
4464680c9d5SAlessio Igor Boganiimage-y := vmlinux.strip
4474bb09281STony Breedsendif
4484bb09281STony Breeds
4494bb09281STony Breeds$(obj)/zImage:		$(addprefix $(obj)/, $(image-y))
4504bb09281STony Breeds	$(Q)rm -f $@; ln $< $@
4514bb09281STony Breeds$(obj)/zImage.initrd:	$(addprefix $(obj)/, $(initrd-y))
4522bf11819SPaul Mackerras	$(Q)rm -f $@; ln $< $@
4536abe248eSMichael Ellerman
4542bf11819SPaul Mackerras# anything not in $(targets)
4556abe248eSMichael Ellermanclean-files += $(image-) $(initrd-) cuImage.* dtbImage.* treeImage.* \
45694b212c2SPaul Mackerras	zImage zImage.initrd zImage.chrp zImage.coff zImage.holly \
4571383a34fSMilton Miller	zImage.miboot zImage.pmac zImage.pseries \
458b58a4575SKumar Gala	zImage.maple simpleImage.* otheros.bld
459b58a4575SKumar Gala
4601b041885SStephen Rothwell# clean up files cached by wrapper
46174ce1896SMasahiro Yamadaclean-kernel-base := vmlinux.strip vmlinux.bin
4621383a34fSMilton Millerclean-kernel := $(addsuffix .gz,$(clean-kernel-base))
4631383a34fSMilton Millerclean-kernel += $(addsuffix .xz,$(clean-kernel-base))
4641b7898eeSOliver O'Halloran# clean-files are relative to $(obj).
4651b7898eeSOliver O'Halloranclean-files += $(addprefix ../../../, $(clean-kernel))
466c762c69eSOliver O'Halloran
4678d613a1dSMasahiro YamadaWRAPPER_OBJDIR := /usr/lib/kernel-wrapper
4688d613a1dSMasahiro YamadaWRAPPER_DTSDIR := /usr/lib/kernel-wrapper/dts
469773f76b1SDavid WoodhouseWRAPPER_BINDIR := /usr/sbin
470773f76b1SDavid WoodhouseINSTALL := install
471773f76b1SDavid Woodhouse
472773f76b1SDavid Woodhouseextra-installed		:= $(patsubst $(obj)/%, $(DESTDIR)$(WRAPPER_OBJDIR)/%, $(extra-y))
473773f76b1SDavid Woodhousehostprogs-installed	:= $(patsubst %, $(DESTDIR)$(WRAPPER_BINDIR)/%, $(hostprogs))
474773f76b1SDavid Woodhousewrapper-installed	:= $(DESTDIR)$(WRAPPER_BINDIR)/wrapper
475773f76b1SDavid Woodhousedts-installed		:= $(patsubst $(dtstree)/%, $(DESTDIR)$(WRAPPER_DTSDIR)/%, $(wildcard $(dtstree)/*.dts))
4765f2fb52fSMasahiro Yamada
477773f76b1SDavid Woodhouseall-installed		:= $(extra-installed) $(hostprogs-installed) $(wrapper-installed) $(dts-installed)
4784d9ef89dSBen Hutchings
479773f76b1SDavid Woodhousequiet_cmd_mkdir           = MKDIR   $(patsubst $(INSTALL_HDR_PATH)/%,%,$@)
480773f76b1SDavid Woodhouse      cmd_mkdir           = mkdir -p $@
481773f76b1SDavid Woodhouse
482773f76b1SDavid Woodhousequiet_cmd_install	  = INSTALL $(patsubst $(DESTDIR)$(WRAPPER_OBJDIR)/%,%,$@)
483773f76b1SDavid Woodhouse      cmd_install	  = $(INSTALL)  -m0644 $(patsubst $(DESTDIR)$(WRAPPER_OBJDIR)/%,$(obj)/%,$@) $@
484773f76b1SDavid Woodhouse
485773f76b1SDavid Woodhousequiet_cmd_install_dts	  = INSTALL $(patsubst $(DESTDIR)$(WRAPPER_DTSDIR)/%,dts/%,$@)
486773f76b1SDavid Woodhouse      cmd_install_dts	  = $(INSTALL)  -m0644 $(patsubst $(DESTDIR)$(WRAPPER_DTSDIR)/%,$(srctree)/$(obj)/dts/%,$@) $@
487773f76b1SDavid Woodhouse
488773f76b1SDavid Woodhousequiet_cmd_install_exe	  = INSTALL $(patsubst $(DESTDIR)$(WRAPPER_BINDIR)/%,%,$@)
489773f76b1SDavid Woodhouse      cmd_install_exe	  = $(INSTALL)  -m0755 $(patsubst $(DESTDIR)$(WRAPPER_BINDIR)/%,$(obj)/%,$@) $@
490773f76b1SDavid Woodhouse
491773f76b1SDavid Woodhousequiet_cmd_install_wrapper = INSTALL $(patsubst $(DESTDIR)$(WRAPPER_BINDIR)/%,%,$@)
492773f76b1SDavid Woodhouse      cmd_install_wrapper = $(INSTALL)  -m0755 $(patsubst $(DESTDIR)$(WRAPPER_BINDIR)/%,$(srctree)/$(obj)/%,$@) $@ ;\
493773f76b1SDavid Woodhouse				sed -i $@ -e 's%^object=.*%object=$(WRAPPER_OBJDIR)%' \
494773f76b1SDavid Woodhouse					  -e 's%^objbin=.*%objbin=$(WRAPPER_BINDIR)%' \
495773f76b1SDavid Woodhouse
496773f76b1SDavid Woodhouse
497773f76b1SDavid Woodhouse$(DESTDIR)$(WRAPPER_OBJDIR) $(DESTDIR)$(WRAPPER_DTSDIR) $(DESTDIR)$(WRAPPER_BINDIR):
498773f76b1SDavid Woodhouse	$(call cmd,mkdir)
499773f76b1SDavid Woodhouse
500773f76b1SDavid Woodhouse$(extra-installed)	: $(DESTDIR)$(WRAPPER_OBJDIR)/% : $(obj)/% | $(DESTDIR)$(WRAPPER_OBJDIR)
501773f76b1SDavid Woodhouse	$(call cmd,install)
502773f76b1SDavid Woodhouse
503773f76b1SDavid Woodhouse$(hostprogs-installed)  : $(DESTDIR)$(WRAPPER_BINDIR)/% : $(obj)/% | $(DESTDIR)$(WRAPPER_BINDIR)
504773f76b1SDavid Woodhouse	$(call cmd,install_exe)
505773f76b1SDavid Woodhouse
506773f76b1SDavid Woodhouse$(dts-installed)	: $(DESTDIR)$(WRAPPER_DTSDIR)/% : $(srctree)/$(obj)/dts/% | $(DESTDIR)$(WRAPPER_DTSDIR)
507773f76b1SDavid Woodhouse	$(call cmd,install_dts)
508773f76b1SDavid Woodhouse
509773f76b1SDavid Woodhouse$(wrapper-installed): $(DESTDIR)$(WRAPPER_BINDIR) $(srctree)/$(obj)/wrapper | $(DESTDIR)$(WRAPPER_BINDIR)
510773f76b1SDavid Woodhouse	$(call cmd,install_wrapper)
511773f76b1SDavid Woodhouse
512773f76b1SDavid Woodhouse$(obj)/bootwrapper_install: $(all-installed)
513773f76b1SDavid Woodhouse