Merge tag 'ntb-3.13' of git://github.com/jonmason/ntb
[linux-drm-fsl-dcu.git] / arch / arm / boot / compressed / Makefile
1 #
2 # linux/arch/arm/boot/compressed/Makefile
3 #
4 # create a compressed vmlinuz image from the original vmlinux
5 #
6
7 OBJS            =
8
9 # Ensure that MMCIF loader code appears early in the image
10 # to minimise that number of bocks that have to be read in
11 # order to load it.
12 ifeq ($(CONFIG_ZBOOT_ROM_MMCIF),y)
13 OBJS            += mmcif-sh7372.o
14 endif
15
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.
19 ifeq ($(CONFIG_ZBOOT_ROM_SH_MOBILE_SDHI),y)
20 OBJS            += sdhi-shmobile.o
21 OBJS            += sdhi-sh7372.o
22 endif
23
24 AFLAGS_head.o += -DTEXT_OFFSET=$(TEXT_OFFSET)
25 HEAD    = head.o
26 OBJS    += misc.o decompress.o
27 ifeq ($(CONFIG_DEBUG_UNCOMPRESS),y)
28 OBJS    += debug.o
29 endif
30 FONTC   = $(srctree)/lib/fonts/font_acorn_8x8.c
31
32 # string library code (-Os is enforced to keep it much smaller)
33 OBJS            += string.o
34 CFLAGS_string.o := -Os
35
36 ifeq ($(CONFIG_ARM_VIRT_EXT),y)
37 OBJS            += hyp-stub.o
38 endif
39
40 #
41 # Architecture dependencies
42 #
43 ifeq ($(CONFIG_ARCH_ACORN),y)
44 OBJS            += ll_char_wr.o font.o
45 endif
46
47 ifeq ($(CONFIG_ARCH_SA1100),y)
48 OBJS            += head-sa1100.o
49 endif
50
51 ifeq ($(CONFIG_CPU_XSCALE),y)
52 OBJS            += head-xscale.o
53 endif
54
55 ifeq ($(CONFIG_PXA_SHARPSL_DETECT_MACH_ID),y)
56 OBJS            += head-sharpsl.o
57 endif
58
59 ifeq ($(CONFIG_CPU_ENDIAN_BE32),y)
60 ifeq ($(CONFIG_CPU_CP15),y)
61 OBJS            += big-endian.o
62 else
63 # The endian should be set by h/w design.
64 endif
65 endif
66
67 ifeq ($(CONFIG_ARCH_SHMOBILE),y)
68 OBJS            += head-shmobile.o
69 endif
70
71 #
72 # We now have a PIC decompressor implementation.  Decompressors running
73 # from RAM should not define ZTEXTADDR.  Decompressors running directly
74 # from ROM or Flash must define ZTEXTADDR (preferably via the config)
75 # FIXME: Previous assignment to ztextaddr-y is lost here. See SHARK
76 ifeq ($(CONFIG_ZBOOT_ROM),y)
77 ZTEXTADDR       := $(CONFIG_ZBOOT_ROM_TEXT)
78 ZBSSADDR        := $(CONFIG_ZBOOT_ROM_BSS)
79 else
80 ZTEXTADDR       := 0
81 ZBSSADDR        := ALIGN(8)
82 endif
83
84 SEDFLAGS        = s/TEXT_START/$(ZTEXTADDR)/;s/BSS_START/$(ZBSSADDR)/
85
86 suffix_$(CONFIG_KERNEL_GZIP) = gzip
87 suffix_$(CONFIG_KERNEL_LZO)  = lzo
88 suffix_$(CONFIG_KERNEL_LZMA) = lzma
89 suffix_$(CONFIG_KERNEL_XZ)   = xzkern
90 suffix_$(CONFIG_KERNEL_LZ4)  = lz4
91
92 # Borrowed libfdt files for the ATAG compatibility mode
93
94 libfdt          := fdt_rw.c fdt_ro.c fdt_wip.c fdt.c
95 libfdt_hdrs     := fdt.h libfdt.h libfdt_internal.h
96
97 libfdt_objs     := $(addsuffix .o, $(basename $(libfdt)))
98
99 $(addprefix $(obj)/,$(libfdt) $(libfdt_hdrs)): $(obj)/%: $(srctree)/scripts/dtc/libfdt/%
100         $(call cmd,shipped)
101
102 $(addprefix $(obj)/,$(libfdt_objs) atags_to_fdt.o): \
103         $(addprefix $(obj)/,$(libfdt_hdrs))
104
105 ifeq ($(CONFIG_ARM_ATAG_DTB_COMPAT),y)
106 OBJS    += $(libfdt_objs) atags_to_fdt.o
107 endif
108
109 targets       := vmlinux vmlinux.lds \
110                  piggy.$(suffix_y) piggy.$(suffix_y).o \
111                  lib1funcs.o lib1funcs.S ashldi3.o ashldi3.S \
112                  font.o font.c head.o misc.o $(OBJS)
113
114 # Make sure files are removed during clean
115 extra-y       += piggy.gzip piggy.lzo piggy.lzma piggy.xzkern piggy.lz4 \
116                  lib1funcs.S ashldi3.S $(libfdt) $(libfdt_hdrs) \
117                  hyp-stub.S
118
119 ifeq ($(CONFIG_FUNCTION_TRACER),y)
120 ORIG_CFLAGS := $(KBUILD_CFLAGS)
121 KBUILD_CFLAGS = $(subst -pg, , $(ORIG_CFLAGS))
122 endif
123
124 ccflags-y := -fpic -mno-single-pic-base -fno-builtin -I$(obj)
125 asflags-y := -DZIMAGE
126
127 # Supply kernel BSS size to the decompressor via a linker symbol.
128 KBSS_SZ = $(shell $(CROSS_COMPILE)size $(obj)/../../../../vmlinux | \
129                 awk 'END{print $$3}')
130 LDFLAGS_vmlinux = --defsym _kernel_bss_size=$(KBSS_SZ)
131 # Supply ZRELADDR to the decompressor via a linker symbol.
132 ifneq ($(CONFIG_AUTO_ZRELADDR),y)
133 LDFLAGS_vmlinux += --defsym zreladdr=$(ZRELADDR)
134 endif
135 ifeq ($(CONFIG_CPU_ENDIAN_BE8),y)
136 LDFLAGS_vmlinux += --be8
137 endif
138 # ?
139 LDFLAGS_vmlinux += -p
140 # Report unresolved symbol references
141 LDFLAGS_vmlinux += --no-undefined
142 # Delete all temporary local symbols
143 LDFLAGS_vmlinux += -X
144 # Next argument is a linker script
145 LDFLAGS_vmlinux += -T
146
147 # For __aeabi_uidivmod
148 lib1funcs = $(obj)/lib1funcs.o
149
150 $(obj)/lib1funcs.S: $(srctree)/arch/$(SRCARCH)/lib/lib1funcs.S
151         $(call cmd,shipped)
152
153 # For __aeabi_llsl
154 ashldi3 = $(obj)/ashldi3.o
155
156 $(obj)/ashldi3.S: $(srctree)/arch/$(SRCARCH)/lib/ashldi3.S
157         $(call cmd,shipped)
158
159 # We need to prevent any GOTOFF relocs being used with references
160 # to symbols in the .bss section since we cannot relocate them
161 # independently from the rest at run time.  This can be achieved by
162 # ensuring that no private .bss symbols exist, as global symbols
163 # always have a GOT entry which is what we need.
164 # The .data section is already discarded by the linker script so no need
165 # to bother about it here.
166 check_for_bad_syms = \
167 bad_syms=$$($(CROSS_COMPILE)nm $@ | sed -n 's/^.\{8\} [bc] \(.*\)/\1/p') && \
168 [ -z "$$bad_syms" ] || \
169   ( echo "following symbols must have non local/private scope:" >&2; \
170     echo "$$bad_syms" >&2; rm -f $@; false )
171
172 check_for_multiple_zreladdr = \
173 if [ $(words $(ZRELADDR)) -gt 1 -a "$(CONFIG_AUTO_ZRELADDR)" = "" ]; then \
174         echo 'multiple zreladdrs: $(ZRELADDR)'; \
175         echo 'This needs CONFIG_AUTO_ZRELADDR to be set'; \
176         false; \
177 fi
178
179 $(obj)/vmlinux: $(obj)/vmlinux.lds $(obj)/$(HEAD) $(obj)/piggy.$(suffix_y).o \
180                 $(addprefix $(obj)/, $(OBJS)) $(lib1funcs) $(ashldi3) FORCE
181         @$(check_for_multiple_zreladdr)
182         $(call if_changed,ld)
183         @$(check_for_bad_syms)
184
185 $(obj)/piggy.$(suffix_y): $(obj)/../Image FORCE
186         $(call if_changed,$(suffix_y))
187
188 $(obj)/piggy.$(suffix_y).o:  $(obj)/piggy.$(suffix_y) FORCE
189
190 CFLAGS_font.o := -Dstatic=
191
192 $(obj)/font.c: $(FONTC)
193         $(call cmd,shipped)
194
195 $(obj)/vmlinux.lds: $(obj)/vmlinux.lds.in arch/arm/boot/Makefile $(KCONFIG_CONFIG)
196         @sed "$(SEDFLAGS)" < $< > $@
197
198 $(obj)/hyp-stub.S: $(srctree)/arch/$(SRCARCH)/kernel/hyp-stub.S
199         $(call cmd,shipped)