blob: 59c723b07091d0c8b111c217ef92b7034c32e9d9 [file] [log] [blame]
wdenk0c8959d2002-08-14 08:04:29 +00001#
Marian Balakowiczf9328632006-09-01 19:49:50 +02002# (C) Copyright 2000-2006
wdenk0c8959d2002-08-14 08:04:29 +00003# Wolfgang Denk, DENX Software Engineering, wd@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
25
Kyle Moffett01baa052011-02-23 06:40:38 +000026## Build a couple of necessary functions into a private libgcc
27LIBGCC = $(obj)libgcc.o
28GLSOBJS += _ashldi3.o
29GLSOBJS += _ashrdi3.o
30GLSOBJS += _lshrdi3.o
31LGOBJS := $(addprefix $(obj),$(GLSOBJS)) \
32 $(addprefix $(obj),$(GLCOBJS))
33
34## But only build it if the user asked for it
35ifdef USE_PRIVATE_LIBGCC
36TARGETS += $(LIBGCC)
37endif
38
Sebastien Carlier6d8962e2010-11-05 15:48:07 +010039LIB = $(obj)lib$(ARCH).o
wdenk0c8959d2002-08-14 08:04:29 +000040
Scott Wood4b919722012-09-20 16:35:21 -050041MINIMAL=
42
43ifdef CONFIG_SPL_BUILD
44ifdef CONFIG_SPL_INIT_MINIMAL
45MINIMAL=y
46endif
47endif
48
49ifdef MINIMAL
Scott Wood06f60ae2012-12-06 13:33:17 +000050COBJS-y += cache.o time.o
51SOBJS-y += ticks.o
Scott Wood4b919722012-09-20 16:35:21 -050052else
53
Marian Balakowicz823afe72008-02-27 11:00:47 +010054SOBJS-y += ppcstring.o
Scott Wood4b919722012-09-20 16:35:21 -050055
56SOBJS-y += ppccache.o
Marian Balakowicz823afe72008-02-27 11:00:47 +010057SOBJS-y += ticks.o
Joakim Tjernlundfc4e1882010-01-19 14:41:55 +010058SOBJS-y += reloc.o
wdenk0c8959d2002-08-14 08:04:29 +000059
Peter Tyser4bbfd3e2010-10-07 22:32:48 -050060COBJS-$(CONFIG_BAT_RW) += bat_rw.o
Stefan Roese083f2e02012-08-16 17:53:18 +020061ifndef CONFIG_SPL_BUILD
Simon Glass660c60c2013-03-11 06:50:01 +000062ifndef CONFIG_SYS_GENERIC_BOARD
Marian Balakowicz823afe72008-02-27 11:00:47 +010063COBJS-y += board.o
Stefan Roese083f2e02012-08-16 17:53:18 +020064endif
Simon Glass660c60c2013-03-11 06:50:01 +000065endif
Marian Balakowicz823afe72008-02-27 11:00:47 +010066COBJS-y += bootm.o
67COBJS-y += cache.o
68COBJS-y += extable.o
69COBJS-y += interrupts.o
Peter Tyser425d3b62009-11-03 23:31:07 -060070COBJS-$(CONFIG_CMD_KGDB) += kgdb.o
Pavel Herrmann8d1165e11a2012-10-09 07:01:56 +000071COBJS-${CONFIG_CMD_IDE} += ide.o
Marian Balakowicz823afe72008-02-27 11:00:47 +010072COBJS-y += time.o
wdenk0c8959d2002-08-14 08:04:29 +000073
Stefan Roese083f2e02012-08-16 17:53:18 +020074# Don't include the MPC5xxx special memcpy into the
75# SPL U-Boot image. memcpy is used in the SPL NOR
76# flash driver. And we need the real, fast memcpy
77# here. We have no problems with unaligned access.
78ifndef CONFIG_SPL_BUILD
Wolfgang Denk4ccd5512010-06-29 01:33:35 +020079# Workaround for local bus unaligned access problems
80# on MPC512x and MPC5200
81ifdef CONFIG_MPC512X
82$(obj)ppcstring.o: AFLAGS += -Dmemcpy=__memcpy
83COBJS-y += memcpy_mpc5200.o
84endif
Wolfgang Denk460c2ce2010-06-21 22:29:59 +020085ifdef CONFIG_MPC5200
86$(obj)ppcstring.o: AFLAGS += -Dmemcpy=__memcpy
Wolfgang Denk4ccd5512010-06-29 01:33:35 +020087COBJS-y += memcpy_mpc5200.o
Wolfgang Denk460c2ce2010-06-21 22:29:59 +020088endif
Stefan Roese083f2e02012-08-16 17:53:18 +020089endif
Wolfgang Denk460c2ce2010-06-21 22:29:59 +020090
Scott Wood4b919722012-09-20 16:35:21 -050091endif # not minimal
92
Stefan Roeseea8256f2012-08-23 08:34:21 +020093ifdef CONFIG_SPL_BUILD
94COBJS-$(CONFIG_SPL_FRAMEWORK) += spl.o
95endif
96
Wolfgang Denk4ccd5512010-06-29 01:33:35 +020097COBJS += $(sort $(COBJS-y))
98
Kyle Moffett01baa052011-02-23 06:40:38 +000099SRCS := $(GLSOBJS:.o=.S) $(GLCOBJS:.o=.c) \
100 $(SOBJS-y:.o=.S) $(COBJS-y:.o=.c)
Wolfgang Denk4ccd5512010-06-29 01:33:35 +0200101OBJS := $(addprefix $(obj),$(SOBJS-y) $(COBJS-y))
102
Kyle Moffett01baa052011-02-23 06:40:38 +0000103TARGETS += $(LIB)
104
105all: $(TARGETS)
106
Marian Balakowiczf9328632006-09-01 19:49:50 +0200107$(LIB): $(obj).depend $(OBJS)
Sebastien Carlier6d8962e2010-11-05 15:48:07 +0100108 $(call cmd_link_o_target, $(OBJS))
wdenk0c8959d2002-08-14 08:04:29 +0000109
Kyle Moffett01baa052011-02-23 06:40:38 +0000110$(LIBGCC): $(obj).depend $(LGOBJS)
111 $(call cmd_link_o_target, $(LGOBJS))
112
wdenk0c8959d2002-08-14 08:04:29 +0000113#########################################################################
114
Marian Balakowiczf9328632006-09-01 19:49:50 +0200115# defines $(obj).depend target
116include $(SRCTREE)/rules.mk
wdenk0c8959d2002-08-14 08:04:29 +0000117
Marian Balakowiczf9328632006-09-01 19:49:50 +0200118sinclude $(obj).depend
wdenk0c8959d2002-08-14 08:04:29 +0000119
120#########################################################################