[PATCH] ppc32: add 440ep support
[linux-3.10.git] / arch / ppc / boot / simple / Makefile
1 # This is far from simple, but I couldn't think of a good name.  This is
2 # for making the 'zImage' or 'zImage.initrd' on a number of targets.
3 #
4 # Author: Tom Rini <trini@mvista.com>
5 #
6 # Notes:
7 # (1) For machines that do not want to use the ELF image directly (including
8 # stripping just the ELF header off), they must set the variables
9 # zimage-$(CONFIG_MACHINE) and zimagerd-$(CONFIG_MACHINE) to the target
10 # that produces the desired image and they must set end-$(CONFIG_MACHINE)
11 # to what will be suffixed to the image filename.
12 # (2) Regardless of (1), to have the resulting image be something other
13 # than 'zImage.elf', set end-$(CONFIG_MACHINE) to be the suffix used for
14 # the zImage, znetboot, and znetbootrd targets.
15 # (3) For machine targets which use the mktree program, you can optionally
16 # set entrypoint-$(CONFIG_MACHINE) to the location which the image should be
17 # loaded at.  The optimal setting for entrypoint-$(CONFIG_MACHINE) is the link
18 # address.
19 # (4) It is advisable to pass in the memory size using BI_MEMSIZE and
20 # get_mem_size(), which is memory controller dependent.  Add in the correct
21 # XXX_memory.o file for this to work, as well as editing the
22 # misc-$(CONFIG_MACHINE) variable.
23
24 boot                            := arch/ppc/boot
25 common                          := $(boot)/common
26 utils                           := $(boot)/utils
27 bootlib                         := $(boot)/lib
28 images                          := $(boot)/images
29 of1275                          := $(boot)/of1275
30 tftpboot                        := /tftpboot
31
32 # Normally, we use the 'misc.c' file for decompress_kernel and
33 # whatnot.  Sometimes we need to override this however.
34 misc-y  := misc.o
35
36 # Normally, we have our images end in .elf, but something we want to
37 # change this.
38 end-y := elf
39
40 # Additionally, we normally don't need to mess with the L2 / L3 caches
41 # if present on 'classic' PPC.
42 cacheflag-y     := -DCLEAR_CACHES=""
43 # This file will flush / disable the L2, and L3 if present.
44 clear_L2_L3     := $(srctree)/$(boot)/simple/clear.S
45
46 #
47 # See arch/ppc/kconfig and arch/ppc/platforms/Kconfig
48 # for definition of what platform each config option refer to.
49 #----------------------------------------------------------------------------
50       zimage-$(CONFIG_CPCI690)          := zImage-STRIPELF
51 zimageinitrd-$(CONFIG_CPCI690)          := zImage.initrd-STRIPELF
52      extra.o-$(CONFIG_CPCI690)          := misc-cpci690.o
53          end-$(CONFIG_CPCI690)          := cpci690
54    cacheflag-$(CONFIG_CPCI690)          := -include $(clear_L2_L3)
55
56       zimage-$(CONFIG_IBM_OPENBIOS)     := zImage-TREE
57 zimageinitrd-$(CONFIG_IBM_OPENBIOS)     := zImage.initrd-TREE
58          end-$(CONFIG_IBM_OPENBIOS)     := treeboot
59         misc-$(CONFIG_IBM_OPENBIOS)     := misc-embedded.o
60
61          end-$(CONFIG_EMBEDDEDBOOT)     := embedded
62         misc-$(CONFIG_EMBEDDEDBOOT)     := misc-embedded.o
63
64       zimage-$(CONFIG_BAMBOO)           := zImage-TREE
65 zimageinitrd-$(CONFIG_BAMBOO)           := zImage.initrd-TREE
66          end-$(CONFIG_BAMBOO)           := bamboo
67   entrypoint-$(CONFIG_BAMBOO)           := 0x01000000
68      extra.o-$(CONFIG_BAMBOO)           := pibs.o
69
70       zimage-$(CONFIG_EBONY)            := zImage-TREE
71 zimageinitrd-$(CONFIG_EBONY)            := zImage.initrd-TREE
72          end-$(CONFIG_EBONY)            := ebony
73   entrypoint-$(CONFIG_EBONY)            := 0x01000000
74      extra.o-$(CONFIG_EBONY)            := openbios.o
75
76       zimage-$(CONFIG_LUAN)             := zImage-TREE
77 zimageinitrd-$(CONFIG_LUAN)             := zImage.initrd-TREE
78          end-$(CONFIG_LUAN)             := luan
79   entrypoint-$(CONFIG_LUAN)             := 0x01000000
80      extra.o-$(CONFIG_LUAN)             := pibs.o
81
82       zimage-$(CONFIG_OCOTEA)           := zImage-TREE
83 zimageinitrd-$(CONFIG_OCOTEA)           := zImage.initrd-TREE
84          end-$(CONFIG_OCOTEA)           := ocotea
85   entrypoint-$(CONFIG_OCOTEA)           := 0x01000000
86      extra.o-$(CONFIG_OCOTEA)           := pibs.o
87
88      extra.o-$(CONFIG_EV64260)          := misc-ev64260.o
89          end-$(CONFIG_EV64260)          := ev64260
90    cacheflag-$(CONFIG_EV64260)          := -include $(clear_L2_L3)
91
92      extra.o-$(CONFIG_CHESTNUT)         := misc-chestnut.o
93          end-$(CONFIG_CHESTNUT)         := chestnut
94
95       zimage-$(CONFIG_GEMINI)           := zImage-STRIPELF
96 zimageinitrd-$(CONFIG_GEMINI)           := zImage.initrd-STRIPELF
97          end-$(CONFIG_GEMINI)           := gemini
98
99      extra.o-$(CONFIG_K2)               := prepmap.o
100          end-$(CONFIG_K2)               := k2
101    cacheflag-$(CONFIG_K2)               := -include $(clear_L2_L3)
102
103      extra.o-$(CONFIG_KATANA)           := misc-katana.o
104          end-$(CONFIG_KATANA)           := katana
105    cacheflag-$(CONFIG_KATANA)           := -include $(clear_L2_L3)
106
107      extra.o-$(CONFIG_RADSTONE_PPC7D)   := misc-radstone_ppc7d.o
108          end-$(CONFIG_RADSTONE_PPC7D)   := radstone_ppc7d
109    cacheflag-$(CONFIG_RADSTONE_PPC7D)   := -include $(clear_L2_L3)
110
111 # kconfig 'feature', only one of these will ever be 'y' at a time.
112 # The rest will be unset.
113 motorola := $(CONFIG_MCPN765)$(CONFIG_MVME5100)$(CONFIG_PRPMC750) \
114 $(CONFIG_PRPMC800)$(CONFIG_LOPEC)$(CONFIG_PPLUS)
115 motorola := $(strip $(motorola))
116 pcore := $(CONFIG_PCORE)$(CONFIG_POWERPMC250)
117
118       zimage-$(motorola)                := zImage-PPLUS
119 zimageinitrd-$(motorola)                := zImage.initrd-PPLUS
120          end-$(motorola)                := pplus
121
122 # Overrides previous assingment
123      extra.o-$(CONFIG_PPLUS)            := prepmap.o
124      extra.o-$(CONFIG_LOPEC)            := mpc10x_memory.o
125
126       zimage-$(pcore)                   := zImage-STRIPELF
127 zimageinitrd-$(pcore)                   := zImage.initrd-STRIPELF
128      extra.o-$(pcore)                   := chrpmap.o
129          end-$(pcore)                   := pcore
130    cacheflag-$(pcore)                   := -include $(clear_L2_L3)
131
132 # Really only valid if CONFIG_6xx=y
133       zimage-$(CONFIG_PPC_PREP)         := zImage-PPLUS
134 zimageinitrd-$(CONFIG_PPC_PREP)         := zImage.initrd-PPLUS
135 ifeq ($(CONFIG_6xx),y)
136      extra.o-$(CONFIG_PPC_PREP)         := prepmap.o
137         misc-$(CONFIG_PPC_PREP)         += misc-prep.o mpc10x_memory.o
138 endif
139          end-$(CONFIG_PPC_PREP)         := prep
140
141          end-$(CONFIG_SANDPOINT)        := sandpoint
142    cacheflag-$(CONFIG_SANDPOINT)        := -include $(clear_L2_L3)
143
144       zimage-$(CONFIG_SPRUCE)           := zImage-TREE
145 zimageinitrd-$(CONFIG_SPRUCE)           := zImage.initrd-TREE
146          end-$(CONFIG_SPRUCE)           := spruce
147   entrypoint-$(CONFIG_SPRUCE)           := 0x00800000
148         misc-$(CONFIG_SPRUCE)           += misc-spruce.o
149
150       zimage-$(CONFIG_LITE5200)         := zImage-STRIPELF
151 zimageinitrd-$(CONFIG_LITE5200)         := zImage.initrd-STRIPELF
152          end-$(CONFIG_LITE5200)         := lite5200
153    cacheflag-$(CONFIG_LITE5200)         := -include $(clear_L2_L3)
154
155
156 # SMP images should have a '.smp' suffix.
157          end-$(CONFIG_SMP)             := $(end-y).smp
158
159 # This is a treeboot that needs init functions until the
160 # boot rom is sorted out (i.e. this is short lived)
161 extra-aflags-$(CONFIG_REDWOOD_4)        := -Wa,-m405
162 extra.o-$(CONFIG_REDWOOD_4)             := rw4/rw4_init.o rw4/rw4_init_brd.o
163 EXTRA_AFLAGS := $(extra-aflags-y)
164 # head.o needs to get the cacheflags defined.
165 AFLAGS_head.o                           += $(cacheflag-y)
166
167 # Linker args.  This specifies where the image will be run at.
168 LD_ARGS                                 := -T $(srctree)/$(boot)/ld.script \
169                                    -Ttext $(CONFIG_BOOT_LOAD) -Bstatic
170 OBJCOPY_ARGS                    := -O elf32-powerpc
171
172 # head.o and relocate.o must be at the start.
173 boot-y                          := head.o relocate.o $(extra.o-y) $(misc-y)
174 boot-$(CONFIG_40x)              += embed_config.o
175 boot-$(CONFIG_8xx)              += embed_config.o
176 boot-$(CONFIG_8260)             += embed_config.o
177 boot-$(CONFIG_BSEIP)            += iic.o
178 boot-$(CONFIG_MBX)              += iic.o pci.o qspan_pci.o
179 boot-$(CONFIG_MV64X60)          += misc-mv64x60.o
180 boot-$(CONFIG_RPXCLASSIC)       += iic.o pci.o qspan_pci.o
181 boot-$(CONFIG_RPXLITE)          += iic.o
182 # Different boards need different serial implementations.
183 ifeq ($(CONFIG_SERIAL_CPM_CONSOLE),y)
184 boot-$(CONFIG_8xx)              += m8xx_tty.o
185 boot-$(CONFIG_8260)             += m8260_tty.o
186 endif
187 boot-$(CONFIG_SERIAL_MPC52xx_CONSOLE)   += mpc52xx_tty.o
188 boot-$(CONFIG_SERIAL_MPSC_CONSOLE)      += mv64x60_tty.o
189
190 LIBS                            := $(common)/lib.a $(bootlib)/lib.a
191 ifeq ($(CONFIG_PPC_PREP),y)
192 LIBS                            += $(of1275)/lib.a
193 endif
194
195 OBJS                            := $(addprefix $(obj)/,$(boot-y))
196
197 # Tools
198 MKBUGBOOT                       := $(utils)/mkbugboot
199 MKPREP                          := $(utils)/mkprep
200 MKTREE                          := $(utils)/mktree
201
202 targets := dummy.o
203
204 $(obj)/zvmlinux: $(OBJS) $(LIBS) $(srctree)/$(boot)/ld.script \
205                 $(images)/vmlinux.gz $(obj)/dummy.o
206         $(OBJCOPY) $(OBJCOPY_ARGS) \
207                 --add-section=.image=$(images)/vmlinux.gz \
208                 --set-section-flags=.image=contents,alloc,load,readonly,data \
209                 $(obj)/dummy.o $(obj)/image.o
210         $(LD) $(LD_ARGS) -o $@ $(OBJS) $(obj)/image.o $(LIBS)
211         $(OBJCOPY) $(OBJCOPY_ARGS) $@ $@ -R .comment -R .stab \
212                 -R .stabstr -R .ramdisk
213
214 $(obj)/zvmlinux.initrd: $(OBJS) $(LIBS) $(srctree)/$(boot)/ld.script \
215                 $(images)/vmlinux.gz $(obj)/dummy.o
216         $(OBJCOPY) $(OBJCOPY_ARGS) \
217                 --add-section=.ramdisk=$(images)/ramdisk.image.gz \
218                 --set-section-flags=.ramdisk=contents,alloc,load,readonly,data \
219                 --add-section=.image=$(images)/vmlinux.gz \
220                 --set-section-flags=.image=contents,alloc,load,readonly,data \
221                 $(obj)/dummy.o $(obj)/image.o
222         $(LD) $(LD_ARGS) -o $@ $(OBJS) $(obj)/image.o $(LIBS)
223         $(OBJCOPY) $(OBJCOPY_ARGS) $@ $@ -R .comment -R .stab \
224                 -R .stabstr
225
226 # Sort-of dummy rules, that let us format the image we want.
227 zImage: $(images)/$(zimage-y) $(obj)/zvmlinux
228         cp -f $(obj)/zvmlinux $(images)/zImage.elf
229         rm -f $(obj)/zvmlinux
230
231 zImage.initrd: $(images)/$(zimageinitrd-y) $(obj)/zvmlinux.initrd
232         cp -f $(obj)/zvmlinux.initrd $(images)/zImage.initrd.elf
233         rm -f $(obj)/zvmlinux.initrd
234
235 znetboot: zImage
236         cp $(images)/zImage.$(end-y) $(tftpboot)/zImage.$(end-y)
237
238 znetboot.initrd: zImage.initrd
239         cp $(images)/zImage.initrd.$(end-y) $(tftpboot)/zImage.initrd.$(end-y)
240
241 $(images)/zImage-STRIPELF: $(obj)/zvmlinux
242         dd if=$(obj)/zvmlinux of=$(images)/zImage.$(end-y) skip=64 bs=1k
243
244 $(images)/zImage.initrd-STRIPELF: $(obj)/zvmlinux.initrd
245         dd if=$(obj)/zvmlinux.initrd of=$(images)/zImage.initrd.$(end-y) \
246                 skip=64 bs=1k
247
248 $(images)/zImage-TREE: $(obj)/zvmlinux $(MKTREE)
249         $(MKTREE) $(obj)/zvmlinux $(images)/zImage.$(end-y) $(ENTRYPOINT)
250
251 $(images)/zImage.initrd-TREE: $(obj)/zvmlinux.initrd $(MKTREE)
252         $(MKTREE) $(obj)/zvmlinux.initrd $(images)/zImage.initrd.$(end-y) \
253                 $(ENTRYPOINT)
254
255 $(images)/zImage-PPLUS: $(obj)/zvmlinux $(MKPREP) $(MKBUGBOOT)
256         $(MKPREP) -pbp $(obj)/zvmlinux $(images)/zImage.$(end-y)
257         $(MKBUGBOOT) $(obj)/zvmlinux $(images)/zImage.bugboot
258
259 $(images)/zImage.initrd-PPLUS: $(obj)/zvmlinux.initrd $(MKPREP) $(MKBUGBOOT)
260         $(MKPREP) -pbp $(obj)/zvmlinux.initrd $(images)/zImage.initrd.$(end-y)
261         $(MKBUGBOOT) $(obj)/zvmlinux.initrd $(images)/zImage.initrd.bugboot