blob: 3ea230aa94b7e061f53b2b4cea9f867bb6c6aa17 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#
2# linux/arch/arm/boot/compressed/Makefile
3#
4# create a compressed vmlinuz image from the original vmlinux
5#
6
Simon Hormanf45b1142011-01-11 04:01:08 +01007OBJS =
8
Simon Horman090ab3f2011-04-26 06:29:53 +01009# Ensure that MMCIF loader code appears early in the image
Simon Hormanf45b1142011-01-11 04:01:08 +010010# to minimise that number of bocks that have to be read in
11# order to load it.
12ifeq ($(CONFIG_ZBOOT_ROM_MMCIF),y)
Simon Hormanf45b1142011-01-11 04:01:08 +010013OBJS += mmcif-sh7372.o
14endif
Simon Horman090ab3f2011-04-26 06:29:53 +010015
16# Ensure that SDHI loader code appears early in the image
17# to minimise that number of bocks that have to be read in
18# order to load it.
19ifeq ($(CONFIG_ZBOOT_ROM_SH_MOBILE_SDHI),y)
20OBJS += sdhi-shmobile.o
21OBJS += sdhi-sh7372.o
Simon Hormanf45b1142011-01-11 04:01:08 +010022endif
23
Eric Miaoe69edc792010-07-05 15:56:50 +020024AFLAGS_head.o += -DTEXT_OFFSET=$(TEXT_OFFSET)
Linus Torvalds1da177e2005-04-16 15:20:36 -070025HEAD = head.o
Simon Hormanf45b1142011-01-11 04:01:08 +010026OBJS += misc.o decompress.o
Shawn Guo3b4af9b2013-03-14 08:48:06 +010027ifeq ($(CONFIG_DEBUG_UNCOMPRESS),y)
28OBJS += debug.o
29endif
Geert Uytterhoevenee89bd62013-06-09 11:46:43 +020030FONTC = $(srctree)/lib/fonts/font_acorn_8x8.c
Linus Torvalds1da177e2005-04-16 15:20:36 -070031
Nicolas Pitredf4879f2011-09-13 21:42:55 -040032# string library code (-Os is enforced to keep it much smaller)
33OBJS += string.o
34CFLAGS_string.o := -Os
35
Dave Martin424e5992012-02-10 18:07:07 -080036ifeq ($(CONFIG_ARM_VIRT_EXT),y)
37OBJS += hyp-stub.o
38endif
39
Vincent Sanders75c34902014-09-18 20:39:15 +010040GCOV_PROFILE := n
41
Linus Torvalds1da177e2005-04-16 15:20:36 -070042#
43# Architecture dependencies
44#
45ifeq ($(CONFIG_ARCH_ACORN),y)
Russell King4486b862007-06-03 18:54:42 +010046OBJS += ll_char_wr.o font.o
Linus Torvalds1da177e2005-04-16 15:20:36 -070047endif
48
Linus Torvalds1da177e2005-04-16 15:20:36 -070049ifeq ($(CONFIG_ARCH_SA1100),y)
50OBJS += head-sa1100.o
51endif
52
53ifeq ($(CONFIG_CPU_XSCALE),y)
54OBJS += head-xscale.o
55endif
56
Eric Miao9c3fca22010-06-23 09:27:32 +080057ifeq ($(CONFIG_PXA_SHARPSL_DETECT_MACH_ID),y)
Linus Torvalds1da177e2005-04-16 15:20:36 -070058OBJS += head-sharpsl.o
59endif
60
Catalin Marinas26584852009-05-30 14:00:18 +010061ifeq ($(CONFIG_CPU_ENDIAN_BE32),y)
Hyok S. Choif12d0d72006-09-26 17:36:37 +090062ifeq ($(CONFIG_CPU_CP15),y)
Linus Torvalds1da177e2005-04-16 15:20:36 -070063OBJS += big-endian.o
Hyok S. Choif12d0d72006-09-26 17:36:37 +090064else
65# The endian should be set by h/w design.
66endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070067endif
68
Laurent Pinchartbf98c1e2013-11-09 13:33:48 +010069ifeq ($(CONFIG_ARCH_SHMOBILE_LEGACY),y)
Kuninori Morimoto9a4af112010-12-01 07:45:00 +010070OBJS += head-shmobile.o
71endif
72
Linus Torvalds1da177e2005-04-16 15:20:36 -070073#
74# We now have a PIC decompressor implementation. Decompressors running
75# from RAM should not define ZTEXTADDR. Decompressors running directly
76# from ROM or Flash must define ZTEXTADDR (preferably via the config)
77# FIXME: Previous assignment to ztextaddr-y is lost here. See SHARK
78ifeq ($(CONFIG_ZBOOT_ROM),y)
79ZTEXTADDR := $(CONFIG_ZBOOT_ROM_TEXT)
80ZBSSADDR := $(CONFIG_ZBOOT_ROM_BSS)
81else
82ZTEXTADDR := 0
Nicolas Pitre3bd2cbb2011-04-21 21:45:08 -040083ZBSSADDR := ALIGN(8)
Linus Torvalds1da177e2005-04-16 15:20:36 -070084endif
85
Russell Kingc79bf922014-06-17 15:00:54 +010086CPPFLAGS_vmlinux.lds := -DTEXT_START="$(ZTEXTADDR)" -DBSS_START="$(ZBSSADDR)"
Linus Torvalds1da177e2005-04-16 15:20:36 -070087
Albin Tonnerree7db7b42010-01-08 14:42:43 -080088suffix_$(CONFIG_KERNEL_GZIP) = gzip
89suffix_$(CONFIG_KERNEL_LZO) = lzo
Albin Tonnerre6e8699f2010-04-03 11:40:28 +010090suffix_$(CONFIG_KERNEL_LZMA) = lzma
Imre Kaloza7f464f2012-01-26 13:08:57 +010091suffix_$(CONFIG_KERNEL_XZ) = xzkern
Kyungsik Leef9b493a2013-07-08 16:01:48 -070092suffix_$(CONFIG_KERNEL_LZ4) = lz4
Albin Tonnerree7db7b42010-01-08 14:42:43 -080093
Nicolas Pitreb90b9a32011-09-13 22:37:07 -040094# Borrowed libfdt files for the ATAG compatibility mode
95
96libfdt := fdt_rw.c fdt_ro.c fdt_wip.c fdt.c
97libfdt_hdrs := fdt.h libfdt.h libfdt_internal.h
98
99libfdt_objs := $(addsuffix .o, $(basename $(libfdt)))
100
101$(addprefix $(obj)/,$(libfdt) $(libfdt_hdrs)): $(obj)/%: $(srctree)/scripts/dtc/libfdt/%
102 $(call cmd,shipped)
103
104$(addprefix $(obj)/,$(libfdt_objs) atags_to_fdt.o): \
105 $(addprefix $(obj)/,$(libfdt_hdrs))
106
107ifeq ($(CONFIG_ARM_ATAG_DTB_COMPAT),y)
108OBJS += $(libfdt_objs) atags_to_fdt.o
109endif
110
Albin Tonnerree7db7b42010-01-08 14:42:43 -0800111targets := vmlinux vmlinux.lds \
112 piggy.$(suffix_y) piggy.$(suffix_y).o \
Kim Phillips017f1612013-11-06 05:15:24 +0100113 lib1funcs.o lib1funcs.S ashldi3.o ashldi3.S bswapsdi2.o \
114 bswapsdi2.S font.o font.c head.o misc.o $(OBJS)
Abhishek Sagar014c2572008-05-31 14:23:50 +0530115
Magnus Dammf1b957d2010-07-28 05:46:21 +0100116# Make sure files are removed during clean
Kyungsik Leef9b493a2013-07-08 16:01:48 -0700117extra-y += piggy.gzip piggy.lzo piggy.lzma piggy.xzkern piggy.lz4 \
Kim Phillips017f1612013-11-06 05:15:24 +0100118 lib1funcs.S ashldi3.S bswapsdi2.S $(libfdt) $(libfdt_hdrs) \
Russell Kingc79bf922014-06-17 15:00:54 +0100119 hyp-stub.S
Magnus Dammf1b957d2010-07-28 05:46:21 +0100120
Steven Rostedt606576c2008-10-06 19:06:12 -0400121ifeq ($(CONFIG_FUNCTION_TRACER),y)
Abhishek Sagar014c2572008-05-31 14:23:50 +0530122ORIG_CFLAGS := $(KBUILD_CFLAGS)
123KBUILD_CFLAGS = $(subst -pg, , $(ORIG_CFLAGS))
124endif
125
Jonathan Austinb8083f82013-03-04 15:17:36 +0100126ccflags-y := -fpic -mno-single-pic-base -fno-builtin -I$(obj)
Arnd Bergmannda94a822013-05-31 22:50:47 +0100127asflags-y := -DZIMAGE
Linus Torvalds1da177e2005-04-16 15:20:36 -0700128
Nicolas Pitre5ffb04f2011-06-12 01:07:33 -0400129# Supply kernel BSS size to the decompressor via a linker symbol.
Janusz Krzysztofik1ec332a2011-12-01 22:45:47 +0100130KBSS_SZ = $(shell $(CROSS_COMPILE)size $(obj)/../../../../vmlinux | \
131 awk 'END{print $$3}')
Nicolas Pitre5ffb04f2011-06-12 01:07:33 -0400132LDFLAGS_vmlinux = --defsym _kernel_bss_size=$(KBSS_SZ)
Russell King9e84ed62010-09-09 22:39:41 +0100133# Supply ZRELADDR to the decompressor via a linker symbol.
134ifneq ($(CONFIG_AUTO_ZRELADDR),y)
Nicolas Pitred239b1d2011-02-21 04:57:38 +0100135LDFLAGS_vmlinux += --defsym zreladdr=$(ZRELADDR)
Russell King9e84ed62010-09-09 22:39:41 +0100136endif
Catalin Marinas26584852009-05-30 14:00:18 +0100137ifeq ($(CONFIG_CPU_ENDIAN_BE8),y)
138LDFLAGS_vmlinux += --be8
139endif
Albin Tonnerree7db7b42010-01-08 14:42:43 -0800140# ?
141LDFLAGS_vmlinux += -p
142# Report unresolved symbol references
143LDFLAGS_vmlinux += --no-undefined
144# Delete all temporary local symbols
145LDFLAGS_vmlinux += -X
146# Next argument is a linker script
147LDFLAGS_vmlinux += -T
148
149# For __aeabi_uidivmod
150lib1funcs = $(obj)/lib1funcs.o
151
Nicolas Pitre63d15142011-09-14 00:16:21 -0400152$(obj)/lib1funcs.S: $(srctree)/arch/$(SRCARCH)/lib/lib1funcs.S
Albin Tonnerree7db7b42010-01-08 14:42:43 -0800153 $(call cmd,shipped)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700154
Imre Kaloza7f464f2012-01-26 13:08:57 +0100155# For __aeabi_llsl
156ashldi3 = $(obj)/ashldi3.o
157
158$(obj)/ashldi3.S: $(srctree)/arch/$(SRCARCH)/lib/ashldi3.S
159 $(call cmd,shipped)
160
Kim Phillips017f1612013-11-06 05:15:24 +0100161# For __bswapsi2, __bswapdi2
162bswapsdi2 = $(obj)/bswapsdi2.o
163
164$(obj)/bswapsdi2.S: $(srctree)/arch/$(SRCARCH)/lib/bswapsdi2.S
165 $(call cmd,shipped)
166
Nicolas Pitre8d7e4cc2011-04-27 14:54:39 -0400167# We need to prevent any GOTOFF relocs being used with references
168# to symbols in the .bss section since we cannot relocate them
169# independently from the rest at run time. This can be achieved by
170# ensuring that no private .bss symbols exist, as global symbols
171# always have a GOT entry which is what we need.
172# The .data section is already discarded by the linker script so no need
173# to bother about it here.
174check_for_bad_syms = \
175bad_syms=$$($(CROSS_COMPILE)nm $@ | sed -n 's/^.\{8\} [bc] \(.*\)/\1/p') && \
176[ -z "$$bad_syms" ] || \
177 ( echo "following symbols must have non local/private scope:" >&2; \
178 echo "$$bad_syms" >&2; rm -f $@; false )
179
Sascha Hauer60aac932011-08-17 14:22:11 +0100180check_for_multiple_zreladdr = \
Rabin Vincent4bdad982011-10-04 14:33:34 +0100181if [ $(words $(ZRELADDR)) -gt 1 -a "$(CONFIG_AUTO_ZRELADDR)" = "" ]; then \
Sascha Hauer60aac932011-08-17 14:22:11 +0100182 echo 'multiple zreladdrs: $(ZRELADDR)'; \
183 echo 'This needs CONFIG_AUTO_ZRELADDR to be set'; \
184 false; \
185fi
186
Albin Tonnerree7db7b42010-01-08 14:42:43 -0800187$(obj)/vmlinux: $(obj)/vmlinux.lds $(obj)/$(HEAD) $(obj)/piggy.$(suffix_y).o \
Kim Phillips017f1612013-11-06 05:15:24 +0100188 $(addprefix $(obj)/, $(OBJS)) $(lib1funcs) $(ashldi3) \
189 $(bswapsdi2) FORCE
Sascha Hauer60aac932011-08-17 14:22:11 +0100190 @$(check_for_multiple_zreladdr)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700191 $(call if_changed,ld)
Nicolas Pitre8d7e4cc2011-04-27 14:54:39 -0400192 @$(check_for_bad_syms)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700193
Albin Tonnerree7db7b42010-01-08 14:42:43 -0800194$(obj)/piggy.$(suffix_y): $(obj)/../Image FORCE
195 $(call if_changed,$(suffix_y))
Linus Torvalds1da177e2005-04-16 15:20:36 -0700196
Albin Tonnerree7db7b42010-01-08 14:42:43 -0800197$(obj)/piggy.$(suffix_y).o: $(obj)/piggy.$(suffix_y) FORCE
Linus Torvalds1da177e2005-04-16 15:20:36 -0700198
Russell King4486b862007-06-03 18:54:42 +0100199CFLAGS_font.o := -Dstatic=
200
201$(obj)/font.c: $(FONTC)
202 $(call cmd,shipped)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700203
Dave Martin424e5992012-02-10 18:07:07 -0800204$(obj)/hyp-stub.S: $(srctree)/arch/$(SRCARCH)/kernel/hyp-stub.S
205 $(call cmd,shipped)