Stefan Roese | 3d6cb3b | 2007-11-03 12:08:28 +0100 | [diff] [blame] | 1 | # |
| 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 | |
| 24 | include $(TOPDIR)/config.mk |
| 25 | include $(TOPDIR)/nand_spl/board/$(BOARDDIR)/config.mk |
| 26 | |
Wolfgang Denk | 3b258e2 | 2011-03-31 16:26:29 -0500 | [diff] [blame] | 27 | nandobj := $(OBJTREE)/nand_spl/ |
| 28 | |
Stefan Roese | 3d6cb3b | 2007-11-03 12:08:28 +0100 | [diff] [blame] | 29 | LDSCRIPT= $(TOPDIR)/nand_spl/board/$(BOARDDIR)/u-boot.lds |
Haiying Wang | 6dc1eceb | 2011-02-22 16:38:05 -0500 | [diff] [blame] | 30 | LDFLAGS := -T $(nandobj)u-boot.lds -Ttext $(CONFIG_SYS_TEXT_BASE) $(LDFLAGS) \ |
| 31 | $(LDFLAGS_FINAL) |
Stefan Roese | 3d6cb3b | 2007-11-03 12:08:28 +0100 | [diff] [blame] | 32 | AFLAGS += -DCONFIG_NAND_SPL |
| 33 | CFLAGS += -DCONFIG_NAND_SPL |
| 34 | |
Stefan Roese | ec724f8 | 2008-06-02 17:13:55 +0200 | [diff] [blame] | 35 | SOBJS = start.o resetvec.o cache.o |
| 36 | COBJS = 44x_spd_ddr2.o nand_boot.o nand_ecc.o ndfc.o |
Stefan Roese | 3d6cb3b | 2007-11-03 12:08:28 +0100 | [diff] [blame] | 37 | |
| 38 | SRCS := $(addprefix $(obj),$(SOBJS:.o=.S) $(COBJS:.o=.c)) |
| 39 | OBJS := $(addprefix $(obj),$(SOBJS) $(COBJS)) |
| 40 | __OBJS := $(SOBJS) $(COBJS) |
Wolfgang Denk | 3b258e2 | 2011-03-31 16:26:29 -0500 | [diff] [blame] | 41 | LNDIR := $(nandobj)board/$(BOARDDIR) |
Stefan Roese | 3d6cb3b | 2007-11-03 12:08:28 +0100 | [diff] [blame] | 42 | |
| 43 | ALL = $(nandobj)u-boot-spl $(nandobj)u-boot-spl.bin $(nandobj)u-boot-spl-16k.bin |
| 44 | |
| 45 | all: $(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 Denk | 1aada9c | 2009-08-17 14:00:53 +0200 | [diff] [blame] | 53 | $(nandobj)u-boot-spl: $(OBJS) $(nandobj)u-boot.lds |
Scott Wood | 767589a | 2010-12-10 15:13:39 -0600 | [diff] [blame] | 54 | cd $(LNDIR) && $(LD) $(LDFLAGS) $(__OBJS) $(PLATFORM_LIBS) \ |
Stefan Roese | 3d6cb3b | 2007-11-03 12:08:28 +0100 | [diff] [blame] | 55 | -Map $(nandobj)u-boot-spl.map \ |
| 56 | -o $(nandobj)u-boot-spl |
| 57 | |
Wolfgang Denk | 1aada9c | 2009-08-17 14:00:53 +0200 | [diff] [blame] | 58 | $(nandobj)u-boot.lds: $(LDSCRIPT) |
| 59 | $(CPP) $(CPPFLAGS) $(LDPPFLAGS) -ansi -D__ASSEMBLY__ -P - <$^ >$@ |
| 60 | |
Stefan Roese | 3d6cb3b | 2007-11-03 12:08:28 +0100 | [diff] [blame] | 61 | # create symbolic links for common files |
| 62 | |
| 63 | # from cpu directory |
Stefan Roese | f2302d4 | 2008-08-06 14:05:38 +0200 | [diff] [blame] | 64 | $(obj)44x_spd_ddr2.c: $(obj)ecc.h |
Stefan Roese | ec724f8 | 2008-06-02 17:13:55 +0200 | [diff] [blame] | 65 | @rm -f $(obj)44x_spd_ddr2.c |
Stefan Roese | a47a12b | 2010-04-15 16:07:28 +0200 | [diff] [blame] | 66 | ln -s $(SRCTREE)/arch/powerpc/cpu/ppc4xx/44x_spd_ddr2.c $(obj)44x_spd_ddr2.c |
Stefan Roese | ec724f8 | 2008-06-02 17:13:55 +0200 | [diff] [blame] | 67 | |
Stefan Roese | 3d6cb3b | 2007-11-03 12:08:28 +0100 | [diff] [blame] | 68 | $(obj)cache.S: |
| 69 | @rm -f $(obj)cache.S |
Stefan Roese | a47a12b | 2010-04-15 16:07:28 +0200 | [diff] [blame] | 70 | ln -s $(SRCTREE)/arch/powerpc/cpu/ppc4xx/cache.S $(obj)cache.S |
Stefan Roese | 3d6cb3b | 2007-11-03 12:08:28 +0100 | [diff] [blame] | 71 | |
Stefan Roese | ec724f8 | 2008-06-02 17:13:55 +0200 | [diff] [blame] | 72 | $(obj)ecc.h: |
| 73 | @rm -f $(obj)ecc.h |
Stefan Roese | a47a12b | 2010-04-15 16:07:28 +0200 | [diff] [blame] | 74 | ln -s $(SRCTREE)/arch/powerpc/cpu/ppc4xx/ecc.h $(obj)ecc.h |
Stefan Roese | ec724f8 | 2008-06-02 17:13:55 +0200 | [diff] [blame] | 75 | |
Stefan Roese | 3d6cb3b | 2007-11-03 12:08:28 +0100 | [diff] [blame] | 76 | $(obj)ndfc.c: |
| 77 | @rm -f $(obj)ndfc.c |
Stefan Roese | 12582ac | 2009-07-16 15:12:48 +0200 | [diff] [blame] | 78 | ln -s $(SRCTREE)/drivers/mtd/nand/ndfc.c $(obj)ndfc.c |
Stefan Roese | 3d6cb3b | 2007-11-03 12:08:28 +0100 | [diff] [blame] | 79 | |
| 80 | $(obj)resetvec.S: |
| 81 | @rm -f $(obj)resetvec.S |
Stefan Roese | a47a12b | 2010-04-15 16:07:28 +0200 | [diff] [blame] | 82 | ln -s $(SRCTREE)/arch/powerpc/cpu/ppc4xx/resetvec.S $(obj)resetvec.S |
Stefan Roese | 3d6cb3b | 2007-11-03 12:08:28 +0100 | [diff] [blame] | 83 | |
| 84 | $(obj)start.S: |
| 85 | @rm -f $(obj)start.S |
Stefan Roese | a47a12b | 2010-04-15 16:07:28 +0200 | [diff] [blame] | 86 | ln -s $(SRCTREE)/arch/powerpc/cpu/ppc4xx/start.S $(obj)start.S |
Stefan Roese | 3d6cb3b | 2007-11-03 12:08:28 +0100 | [diff] [blame] | 87 | |
Stefan Roese | 3d6cb3b | 2007-11-03 12:08:28 +0100 | [diff] [blame] | 88 | # 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 Roese | fb83a65 | 2007-12-28 06:06:04 +0100 | [diff] [blame] | 96 | ln -s $(SRCTREE)/drivers/mtd/nand/nand_ecc.c $(obj)nand_ecc.c |
Stefan Roese | 3d6cb3b | 2007-11-03 12:08:28 +0100 | [diff] [blame] | 97 | |
| 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 |
| 107 | include $(SRCTREE)/rules.mk |
| 108 | |
| 109 | sinclude $(obj).depend |
| 110 | |
| 111 | ######################################################################### |