blob: 1053ce33b9930c8f2c5dfe555cb1d70b65384d06 [file] [log] [blame]
Stefan Roese3d6cb3b2007-11-03 12:08:28 +01001#
2# (C) Copyright 2007
3# Stefan Roese, DENX Software Engineering, sr@denx.de.
4#
5# See file CREDITS for list of people who contributed to this
6# project.
7#
8# This program is free software; you can redistribute it and/or
9# modify it under the terms of the GNU General Public License as
10# published by the Free Software Foundation; either version 2 of
11# the License, or (at your option) any later version.
12#
13# This program is distributed in the hope that it will be useful,
14# but WITHOUT ANY WARRANTY; without even the implied warranty of
15# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16# GNU General Public License for more details.
17#
18# You should have received a copy of the GNU General Public License
19# along with this program; if not, write to the Free Software
20# Foundation, Inc., 59 Temple Place, Suite 330, Boston,
21# MA 02111-1307 USA
22#
23
24include $(TOPDIR)/config.mk
25include $(TOPDIR)/nand_spl/board/$(BOARDDIR)/config.mk
26
27LDSCRIPT= $(TOPDIR)/nand_spl/board/$(BOARDDIR)/u-boot.lds
Haiying Wang6dc1eceb2011-02-22 16:38:05 -050028LDFLAGS := -T $(nandobj)u-boot.lds -Ttext $(CONFIG_SYS_TEXT_BASE) $(LDFLAGS) \
29 $(LDFLAGS_FINAL)
Stefan Roese3d6cb3b2007-11-03 12:08:28 +010030AFLAGS += -DCONFIG_NAND_SPL
31CFLAGS += -DCONFIG_NAND_SPL
32
Stefan Roeseec724f82008-06-02 17:13:55 +020033SOBJS = start.o resetvec.o cache.o
34COBJS = 44x_spd_ddr2.o nand_boot.o nand_ecc.o ndfc.o
Stefan Roese3d6cb3b2007-11-03 12:08:28 +010035
36SRCS := $(addprefix $(obj),$(SOBJS:.o=.S) $(COBJS:.o=.c))
37OBJS := $(addprefix $(obj),$(SOBJS) $(COBJS))
38__OBJS := $(SOBJS) $(COBJS)
39LNDIR := $(OBJTREE)/nand_spl/board/$(BOARDDIR)
40
41nandobj := $(OBJTREE)/nand_spl/
42
43ALL = $(nandobj)u-boot-spl $(nandobj)u-boot-spl.bin $(nandobj)u-boot-spl-16k.bin
44
45all: $(obj).depend $(ALL)
46
47$(nandobj)u-boot-spl-16k.bin: $(nandobj)u-boot-spl
48 $(OBJCOPY) ${OBJCFLAGS} --pad-to=$(PAD_TO) -O binary $< $@
49
50$(nandobj)u-boot-spl.bin: $(nandobj)u-boot-spl
51 $(OBJCOPY) ${OBJCFLAGS} -O binary $< $@
52
Wolfgang Denk1aada9c2009-08-17 14:00:53 +020053$(nandobj)u-boot-spl: $(OBJS) $(nandobj)u-boot.lds
Scott Wood767589a2010-12-10 15:13:39 -060054 cd $(LNDIR) && $(LD) $(LDFLAGS) $(__OBJS) $(PLATFORM_LIBS) \
Stefan Roese3d6cb3b2007-11-03 12:08:28 +010055 -Map $(nandobj)u-boot-spl.map \
56 -o $(nandobj)u-boot-spl
57
Wolfgang Denk1aada9c2009-08-17 14:00:53 +020058$(nandobj)u-boot.lds: $(LDSCRIPT)
59 $(CPP) $(CPPFLAGS) $(LDPPFLAGS) -ansi -D__ASSEMBLY__ -P - <$^ >$@
60
Stefan Roese3d6cb3b2007-11-03 12:08:28 +010061# create symbolic links for common files
62
63# from cpu directory
Stefan Roesef2302d42008-08-06 14:05:38 +020064$(obj)44x_spd_ddr2.c: $(obj)ecc.h
Stefan Roeseec724f82008-06-02 17:13:55 +020065 @rm -f $(obj)44x_spd_ddr2.c
Stefan Roesea47a12b2010-04-15 16:07:28 +020066 ln -s $(SRCTREE)/arch/powerpc/cpu/ppc4xx/44x_spd_ddr2.c $(obj)44x_spd_ddr2.c
Stefan Roeseec724f82008-06-02 17:13:55 +020067
Stefan Roese3d6cb3b2007-11-03 12:08:28 +010068$(obj)cache.S:
69 @rm -f $(obj)cache.S
Stefan Roesea47a12b2010-04-15 16:07:28 +020070 ln -s $(SRCTREE)/arch/powerpc/cpu/ppc4xx/cache.S $(obj)cache.S
Stefan Roese3d6cb3b2007-11-03 12:08:28 +010071
Stefan Roeseec724f82008-06-02 17:13:55 +020072$(obj)ecc.h:
73 @rm -f $(obj)ecc.h
Stefan Roesea47a12b2010-04-15 16:07:28 +020074 ln -s $(SRCTREE)/arch/powerpc/cpu/ppc4xx/ecc.h $(obj)ecc.h
Stefan Roeseec724f82008-06-02 17:13:55 +020075
Stefan Roese3d6cb3b2007-11-03 12:08:28 +010076$(obj)ndfc.c:
77 @rm -f $(obj)ndfc.c
Stefan Roese12582ac2009-07-16 15:12:48 +020078 ln -s $(SRCTREE)/drivers/mtd/nand/ndfc.c $(obj)ndfc.c
Stefan Roese3d6cb3b2007-11-03 12:08:28 +010079
80$(obj)resetvec.S:
81 @rm -f $(obj)resetvec.S
Stefan Roesea47a12b2010-04-15 16:07:28 +020082 ln -s $(SRCTREE)/arch/powerpc/cpu/ppc4xx/resetvec.S $(obj)resetvec.S
Stefan Roese3d6cb3b2007-11-03 12:08:28 +010083
84$(obj)start.S:
85 @rm -f $(obj)start.S
Stefan Roesea47a12b2010-04-15 16:07:28 +020086 ln -s $(SRCTREE)/arch/powerpc/cpu/ppc4xx/start.S $(obj)start.S
Stefan Roese3d6cb3b2007-11-03 12:08:28 +010087
Stefan Roese3d6cb3b2007-11-03 12:08:28 +010088# from nand_spl directory
89$(obj)nand_boot.c:
90 @rm -f $(obj)nand_boot.c
91 ln -s $(SRCTREE)/nand_spl/nand_boot.c $(obj)nand_boot.c
92
93# from drivers/nand directory
94$(obj)nand_ecc.c:
95 @rm -f $(obj)nand_ecc.c
Stefan Roesefb83a652007-12-28 06:06:04 +010096 ln -s $(SRCTREE)/drivers/mtd/nand/nand_ecc.c $(obj)nand_ecc.c
Stefan Roese3d6cb3b2007-11-03 12:08:28 +010097
98#########################################################################
99
100$(obj)%.o: $(obj)%.S
101 $(CC) $(AFLAGS) -c -o $@ $<
102
103$(obj)%.o: $(obj)%.c
104 $(CC) $(CFLAGS) -c -o $@ $<
105
106# defines $(obj).depend target
107include $(SRCTREE)/rules.mk
108
109sinclude $(obj).depend
110
111#########################################################################