Merge branch 'master' of git://www.denx.de/git/u-boot-mmc
[platform/kernel/u-boot.git] / arch / arm / imx-common / Makefile
1 #
2 # (C) Copyright 2000-2006
3 # Wolfgang Denk, DENX Software Engineering, wd@denx.de.
4 #
5 # (C) Copyright 2011 Freescale Semiconductor, Inc.
6 #
7 # See file CREDITS for list of people who contributed to this
8 # project.
9 #
10 # This program is free software; you can redistribute it and/or
11 # modify it under the terms of the GNU General Public License as
12 # published by the Free Software Foundation; either version 2 of
13 # the License, or (at your option) any later version.
14 #
15 # This program is distributed in the hope that it will be useful,
16 # but WITHOUT ANY WARRANTY; without even the implied warranty of
17 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18 # GNU General Public License for more details.
19 #
20 # You should have received a copy of the GNU General Public License
21 # along with this program; if not, write to the Free Software
22 # Foundation, Inc., 59 Temple Place, Suite 330, Boston,
23 # MA 02111-1307 USA
24 #
25
26 include $(TOPDIR)/config.mk
27
28 LIB     = $(obj)libimx-common.o
29
30 ifeq ($(SOC),$(filter $(SOC),mx25 mx35 mx5 mx6 vf610))
31 COBJS-y = iomux-v3.o
32 endif
33 ifeq ($(SOC),$(filter $(SOC),mx5 mx6))
34 COBJS-y += timer.o cpu.o speed.o
35 COBJS-$(CONFIG_I2C_MXC) += i2c-mxv7.o
36 endif
37 ifeq ($(SOC),$(filter $(SOC),mx6 mxs))
38 COBJS-y += misc.o
39 endif
40 COBJS-$(CONFIG_CMD_BMODE) += cmd_bmode.o
41 COBJS-$(CONFIG_CMD_HDMIDETECT) += cmd_hdmidet.o
42 COBJS   := $(sort $(COBJS-y))
43
44 SRCS    := $(SOBJS:.o=.S) $(COBJS:.o=.c)
45 OBJS    := $(addprefix $(obj),$(SOBJS) $(COBJS))
46
47 all:    $(obj).depend $(LIB)
48
49 $(LIB): $(OBJS)
50         $(call cmd_link_o_target, $(OBJS))
51
52 $(OBJTREE)/$(patsubst "%",%,$(CONFIG_IMX_CONFIG)).cfgtmp: $(OBJTREE)/%.cfgtmp : $(SRCTREE)/%
53         mkdir -p $(dir $@)
54         $(CC) -E -x c $< $(CPPFLAGS) -o $@
55
56 $(OBJTREE)/u-boot.imx: $(OBJTREE)/u-boot.bin $(OBJTREE)/$(patsubst "%",%,$(CONFIG_IMX_CONFIG)).cfgtmp
57         $(OBJTREE)/tools/mkimage -n $(filter-out %.bin,$^) -T imximage \
58         -e $(CONFIG_SYS_TEXT_BASE) -d $< $@
59
60 $(OBJTREE)/SPL: $(OBJTREE)/spl/u-boot-spl.bin $(OBJTREE)/$(patsubst "%",%,$(CONFIG_IMX_CONFIG)).cfgtmp
61         $(OBJTREE)/tools/mkimage -n $(filter-out %.bin,$^) -T imximage \
62         -e $(CONFIG_SPL_TEXT_BASE) -d $< $@
63
64 $(OBJTREE)/u-boot-with-spl.imx: $(OBJTREE)/SPL $(OBJTREE)/u-boot.bin
65         $(OBJCOPY) ${OBJCFLAGS} --pad-to=$(CONFIG_SPL_PAD_TO) \
66                 -I binary -O binary $< $(OBJTREE)/spl/u-boot-spl-pad.imx
67         $(OBJTREE)/tools/mkimage -A arm -O U-Boot -a $(CONFIG_SYS_TEXT_BASE) \
68                 -e $(CONFIG_SYS_TEXT_BASE) -C none -d $(OBJTREE)/u-boot.bin \
69                 $(OBJTREE)/u-boot.uim
70         cat $(OBJTREE)/spl/u-boot-spl-pad.imx $(OBJTREE)/u-boot.uim > $@
71         rm $(OBJTREE)/spl/u-boot-spl-pad.imx $(OBJTREE)/u-boot.uim
72
73 $(OBJTREE)/u-boot-with-nand-spl.imx: $(OBJTREE)/SPL $(OBJTREE)/u-boot.bin
74         (echo -ne '\x00\x00\x00\x00\x46\x43\x42\x20\x01' && \
75                         dd bs=1015 count=1 if=/dev/zero 2>/dev/null) | \
76                 cat - $< > $(OBJTREE)/spl/u-boot-nand-spl.imx
77         $(OBJCOPY) ${OBJCFLAGS} --pad-to=$(CONFIG_SPL_PAD_TO) \
78                 -I binary -O binary $(OBJTREE)/spl/u-boot-nand-spl.imx \
79                 $(OBJTREE)/spl/u-boot-nand-spl-pad.imx
80         rm $(OBJTREE)/spl/u-boot-nand-spl.imx
81         $(OBJTREE)/tools/mkimage -A arm -O U-Boot -a $(CONFIG_SYS_TEXT_BASE) \
82                 -e $(CONFIG_SYS_TEXT_BASE) -C none -d $(OBJTREE)/u-boot.bin \
83                 $(OBJTREE)/u-boot.uim
84         cat $(OBJTREE)/spl/u-boot-nand-spl-pad.imx $(OBJTREE)/u-boot.uim > $@
85         rm $(OBJTREE)/spl/u-boot-nand-spl-pad.imx $(OBJTREE)/u-boot.uim
86
87
88 #########################################################################
89
90 # defines $(obj).depend target
91 include $(SRCTREE)/rules.mk
92
93 sinclude $(obj).depend
94
95 #########################################################################