blob: a517153a13eabdad582b6b6f75080cf93f699595 [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
Russell King4486b862007-06-03 18:54:42 +010027FONTC = $(srctree)/drivers/video/console/font_acorn_8x8.c
Linus Torvalds1da177e2005-04-16 15:20:36 -070028
Nicolas Pitredf4879f2011-09-13 21:42:55 -040029# string library code (-Os is enforced to keep it much smaller)
30OBJS += string.o
31CFLAGS_string.o := -Os
32
Dave Martin424e5992012-02-10 18:07:07 -080033ifeq ($(CONFIG_ARM_VIRT_EXT),y)
34OBJS += hyp-stub.o
35endif
36
Linus Torvalds1da177e2005-04-16 15:20:36 -070037#
38# Architecture dependencies
39#
40ifeq ($(CONFIG_ARCH_ACORN),y)
Russell King4486b862007-06-03 18:54:42 +010041OBJS += ll_char_wr.o font.o
Linus Torvalds1da177e2005-04-16 15:20:36 -070042endif
43
44ifeq ($(CONFIG_ARCH_SHARK),y)
45OBJS += head-shark.o ofw-shark.o
46endif
47
Linus Torvalds1da177e2005-04-16 15:20:36 -070048ifeq ($(CONFIG_ARCH_P720T),y)
49# Borrow this code from SA1100
50OBJS += head-sa1100.o
51endif
52
53ifeq ($(CONFIG_ARCH_SA1100),y)
54OBJS += head-sa1100.o
55endif
56
Alexey Charkov21f47fb2010-12-23 13:11:21 +010057ifeq ($(CONFIG_ARCH_VT8500),y)
58OBJS += head-vt8500.o
59endif
60
Linus Torvalds1da177e2005-04-16 15:20:36 -070061ifeq ($(CONFIG_CPU_XSCALE),y)
62OBJS += head-xscale.o
63endif
64
Eric Miao9c3fca22010-06-23 09:27:32 +080065ifeq ($(CONFIG_PXA_SHARPSL_DETECT_MACH_ID),y)
Linus Torvalds1da177e2005-04-16 15:20:36 -070066OBJS += head-sharpsl.o
67endif
68
Catalin Marinas26584852009-05-30 14:00:18 +010069ifeq ($(CONFIG_CPU_ENDIAN_BE32),y)
Hyok S. Choif12d0d72006-09-26 17:36:37 +090070ifeq ($(CONFIG_CPU_CP15),y)
Linus Torvalds1da177e2005-04-16 15:20:36 -070071OBJS += big-endian.o
Hyok S. Choif12d0d72006-09-26 17:36:37 +090072else
73# The endian should be set by h/w design.
74endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070075endif
76
Kuninori Morimoto9a4af112010-12-01 07:45:00 +010077ifeq ($(CONFIG_ARCH_SHMOBILE),y)
78OBJS += head-shmobile.o
79endif
80
Linus Torvalds1da177e2005-04-16 15:20:36 -070081#
82# We now have a PIC decompressor implementation. Decompressors running
83# from RAM should not define ZTEXTADDR. Decompressors running directly
84# from ROM or Flash must define ZTEXTADDR (preferably via the config)
85# FIXME: Previous assignment to ztextaddr-y is lost here. See SHARK
86ifeq ($(CONFIG_ZBOOT_ROM),y)
87ZTEXTADDR := $(CONFIG_ZBOOT_ROM_TEXT)
88ZBSSADDR := $(CONFIG_ZBOOT_ROM_BSS)
89else
90ZTEXTADDR := 0
Nicolas Pitre3bd2cbb2011-04-21 21:45:08 -040091ZBSSADDR := ALIGN(8)
Linus Torvalds1da177e2005-04-16 15:20:36 -070092endif
93
94SEDFLAGS = s/TEXT_START/$(ZTEXTADDR)/;s/BSS_START/$(ZBSSADDR)/
95
Albin Tonnerree7db7b42010-01-08 14:42:43 -080096suffix_$(CONFIG_KERNEL_GZIP) = gzip
97suffix_$(CONFIG_KERNEL_LZO) = lzo
Albin Tonnerre6e8699f2010-04-03 11:40:28 +010098suffix_$(CONFIG_KERNEL_LZMA) = lzma
Imre Kaloza7f464f2012-01-26 13:08:57 +010099suffix_$(CONFIG_KERNEL_XZ) = xzkern
Albin Tonnerree7db7b42010-01-08 14:42:43 -0800100
Nicolas Pitreb90b9a32011-09-13 22:37:07 -0400101# Borrowed libfdt files for the ATAG compatibility mode
102
103libfdt := fdt_rw.c fdt_ro.c fdt_wip.c fdt.c
104libfdt_hdrs := fdt.h libfdt.h libfdt_internal.h
105
106libfdt_objs := $(addsuffix .o, $(basename $(libfdt)))
107
108$(addprefix $(obj)/,$(libfdt) $(libfdt_hdrs)): $(obj)/%: $(srctree)/scripts/dtc/libfdt/%
109 $(call cmd,shipped)
110
111$(addprefix $(obj)/,$(libfdt_objs) atags_to_fdt.o): \
112 $(addprefix $(obj)/,$(libfdt_hdrs))
113
114ifeq ($(CONFIG_ARM_ATAG_DTB_COMPAT),y)
115OBJS += $(libfdt_objs) atags_to_fdt.o
116endif
117
Albin Tonnerree7db7b42010-01-08 14:42:43 -0800118targets := vmlinux vmlinux.lds \
119 piggy.$(suffix_y) piggy.$(suffix_y).o \
Imre Kaloza7f464f2012-01-26 13:08:57 +0100120 lib1funcs.o lib1funcs.S ashldi3.o ashldi3.S \
121 font.o font.c head.o misc.o $(OBJS)
Abhishek Sagar014c2572008-05-31 14:23:50 +0530122
Magnus Dammf1b957d2010-07-28 05:46:21 +0100123# Make sure files are removed during clean
Imre Kaloza7f464f2012-01-26 13:08:57 +0100124extra-y += piggy.gzip piggy.lzo piggy.lzma piggy.xzkern \
125 lib1funcs.S ashldi3.S $(libfdt) $(libfdt_hdrs)
Magnus Dammf1b957d2010-07-28 05:46:21 +0100126
Steven Rostedt606576c2008-10-06 19:06:12 -0400127ifeq ($(CONFIG_FUNCTION_TRACER),y)
Abhishek Sagar014c2572008-05-31 14:23:50 +0530128ORIG_CFLAGS := $(KBUILD_CFLAGS)
129KBUILD_CFLAGS = $(subst -pg, , $(ORIG_CFLAGS))
130endif
131
Nicolas Pitreb90b9a32011-09-13 22:37:07 -0400132ccflags-y := -fpic -fno-builtin -I$(obj)
Dave Martin424e5992012-02-10 18:07:07 -0800133asflags-y := -Wa,-march=all -DZIMAGE
Linus Torvalds1da177e2005-04-16 15:20:36 -0700134
Nicolas Pitre5ffb04f2011-06-12 01:07:33 -0400135# Supply kernel BSS size to the decompressor via a linker symbol.
Janusz Krzysztofik1ec332a2011-12-01 22:45:47 +0100136KBSS_SZ = $(shell $(CROSS_COMPILE)size $(obj)/../../../../vmlinux | \
137 awk 'END{print $$3}')
Nicolas Pitre5ffb04f2011-06-12 01:07:33 -0400138LDFLAGS_vmlinux = --defsym _kernel_bss_size=$(KBSS_SZ)
Russell King9e84ed62010-09-09 22:39:41 +0100139# Supply ZRELADDR to the decompressor via a linker symbol.
140ifneq ($(CONFIG_AUTO_ZRELADDR),y)
Nicolas Pitred239b1d2011-02-21 04:57:38 +0100141LDFLAGS_vmlinux += --defsym zreladdr=$(ZRELADDR)
Russell King9e84ed62010-09-09 22:39:41 +0100142endif
Catalin Marinas26584852009-05-30 14:00:18 +0100143ifeq ($(CONFIG_CPU_ENDIAN_BE8),y)
144LDFLAGS_vmlinux += --be8
145endif
Albin Tonnerree7db7b42010-01-08 14:42:43 -0800146# ?
147LDFLAGS_vmlinux += -p
148# Report unresolved symbol references
149LDFLAGS_vmlinux += --no-undefined
150# Delete all temporary local symbols
151LDFLAGS_vmlinux += -X
152# Next argument is a linker script
153LDFLAGS_vmlinux += -T
154
155# For __aeabi_uidivmod
156lib1funcs = $(obj)/lib1funcs.o
157
Nicolas Pitre63d15142011-09-14 00:16:21 -0400158$(obj)/lib1funcs.S: $(srctree)/arch/$(SRCARCH)/lib/lib1funcs.S
Albin Tonnerree7db7b42010-01-08 14:42:43 -0800159 $(call cmd,shipped)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700160
Imre Kaloza7f464f2012-01-26 13:08:57 +0100161# For __aeabi_llsl
162ashldi3 = $(obj)/ashldi3.o
163
164$(obj)/ashldi3.S: $(srctree)/arch/$(SRCARCH)/lib/ashldi3.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 \
Imre Kaloza7f464f2012-01-26 13:08:57 +0100188 $(addprefix $(obj)/, $(OBJS)) $(lib1funcs) $(ashldi3) FORCE
Sascha Hauer60aac932011-08-17 14:22:11 +0100189 @$(check_for_multiple_zreladdr)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700190 $(call if_changed,ld)
Nicolas Pitre8d7e4cc2011-04-27 14:54:39 -0400191 @$(check_for_bad_syms)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700192
Albin Tonnerree7db7b42010-01-08 14:42:43 -0800193$(obj)/piggy.$(suffix_y): $(obj)/../Image FORCE
194 $(call if_changed,$(suffix_y))
Linus Torvalds1da177e2005-04-16 15:20:36 -0700195
Albin Tonnerree7db7b42010-01-08 14:42:43 -0800196$(obj)/piggy.$(suffix_y).o: $(obj)/piggy.$(suffix_y) FORCE
Linus Torvalds1da177e2005-04-16 15:20:36 -0700197
Russell King4486b862007-06-03 18:54:42 +0100198CFLAGS_font.o := -Dstatic=
199
200$(obj)/font.c: $(FONTC)
201 $(call cmd,shipped)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700202
Russell Kingd93c3332010-09-19 16:16:58 +0100203$(obj)/vmlinux.lds: $(obj)/vmlinux.lds.in arch/arm/boot/Makefile $(KCONFIG_CONFIG)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700204 @sed "$(SEDFLAGS)" < $< > $@
Dave Martin424e5992012-02-10 18:07:07 -0800205
206$(obj)/hyp-stub.S: $(srctree)/arch/$(SRCARCH)/kernel/hyp-stub.S
207 $(call cmd,shipped)