blob: cdd62a2061f848dcc2fea75ce373e37e00856e8d [file] [log] [blame]
wdenk0c8959d2002-08-14 08:04:29 +00001#
Marian Balakowiczd62379d2006-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 Moffett78d58de2011-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 Carliera8d426f2010-11-05 15:48:07 +010039LIB = $(obj)lib$(ARCH).o
wdenk0c8959d2002-08-14 08:04:29 +000040
Marian Balakowicz699ffe52008-02-27 11:00:47 +010041SOBJS-y += ppccache.o
42SOBJS-y += ppcstring.o
43SOBJS-y += ticks.o
Joakim Tjernlund4ff6bc02010-01-19 14:41:55 +010044SOBJS-y += reloc.o
wdenk0c8959d2002-08-14 08:04:29 +000045
Peter Tyser86dee4a2010-10-07 22:32:48 -050046COBJS-$(CONFIG_BAT_RW) += bat_rw.o
Marian Balakowicz699ffe52008-02-27 11:00:47 +010047COBJS-y += board.o
48COBJS-y += bootm.o
Stefan Roeseed7aaf82010-04-28 10:47:36 +020049COBJS-$(CONFIG_BOOTCOUNT_LIMIT) += bootcount.o
Marian Balakowicz699ffe52008-02-27 11:00:47 +010050COBJS-y += cache.o
51COBJS-y += extable.o
52COBJS-y += interrupts.o
Peter Tyserda1a4fc2009-11-03 23:31:07 -060053COBJS-$(CONFIG_CMD_KGDB) += kgdb.o
Marian Balakowicz699ffe52008-02-27 11:00:47 +010054COBJS-y += time.o
wdenk0c8959d2002-08-14 08:04:29 +000055
Wolfgang Denk85aa2c42010-06-29 01:33:35 +020056# Workaround for local bus unaligned access problems
57# on MPC512x and MPC5200
58ifdef CONFIG_MPC512X
59$(obj)ppcstring.o: AFLAGS += -Dmemcpy=__memcpy
60COBJS-y += memcpy_mpc5200.o
61endif
Wolfgang Denk16126092010-06-21 22:29:59 +020062ifdef CONFIG_MPC5200
63$(obj)ppcstring.o: AFLAGS += -Dmemcpy=__memcpy
Wolfgang Denk85aa2c42010-06-29 01:33:35 +020064COBJS-y += memcpy_mpc5200.o
Wolfgang Denk16126092010-06-21 22:29:59 +020065endif
66
Wolfgang Denk85aa2c42010-06-29 01:33:35 +020067COBJS += $(sort $(COBJS-y))
68
Kyle Moffett78d58de2011-02-23 06:40:38 +000069SRCS := $(GLSOBJS:.o=.S) $(GLCOBJS:.o=.c) \
70 $(SOBJS-y:.o=.S) $(COBJS-y:.o=.c)
Wolfgang Denk85aa2c42010-06-29 01:33:35 +020071OBJS := $(addprefix $(obj),$(SOBJS-y) $(COBJS-y))
72
Kyle Moffett78d58de2011-02-23 06:40:38 +000073TARGETS += $(LIB)
74
75all: $(TARGETS)
76
Marian Balakowiczd62379d2006-09-01 19:49:50 +020077$(LIB): $(obj).depend $(OBJS)
Peter Tyser95728f22009-09-21 11:20:26 -050078 @if ! $(CROSS_COMPILE)readelf -S $(OBJS) | grep -q '\.fixup.*PROGBITS';\
79 then \
80 echo "ERROR: Your compiler doesn't generate .fixup sections!";\
81 echo " Upgrade to a recent toolchain."; \
82 exit 1; \
83 fi;
Sebastien Carliera8d426f2010-11-05 15:48:07 +010084 $(call cmd_link_o_target, $(OBJS))
wdenk0c8959d2002-08-14 08:04:29 +000085
Kyle Moffett78d58de2011-02-23 06:40:38 +000086$(LIBGCC): $(obj).depend $(LGOBJS)
87 $(call cmd_link_o_target, $(LGOBJS))
88
wdenk0c8959d2002-08-14 08:04:29 +000089#########################################################################
90
Marian Balakowiczd62379d2006-09-01 19:49:50 +020091# defines $(obj).depend target
92include $(SRCTREE)/rules.mk
wdenk0c8959d2002-08-14 08:04:29 +000093
Marian Balakowiczd62379d2006-09-01 19:49:50 +020094sinclude $(obj).depend
wdenk0c8959d2002-08-14 08:04:29 +000095
96#########################################################################