wdenk | 0c8959d | 2002-08-14 08:04:29 +0000 | [diff] [blame] | 1 | # |
Marian Balakowicz | f932863 | 2006-09-01 19:49:50 +0200 | [diff] [blame] | 2 | # (C) Copyright 2000-2006 |
wdenk | 0c8959d | 2002-08-14 08:04:29 +0000 | [diff] [blame] | 3 | # 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 | |
| 24 | include $(TOPDIR)/config.mk |
| 25 | |
Kyle Moffett | 01baa05 | 2011-02-23 06:40:38 +0000 | [diff] [blame] | 26 | ## Build a couple of necessary functions into a private libgcc |
| 27 | LIBGCC = $(obj)libgcc.o |
| 28 | GLSOBJS += _ashldi3.o |
| 29 | GLSOBJS += _ashrdi3.o |
| 30 | GLSOBJS += _lshrdi3.o |
| 31 | LGOBJS := $(addprefix $(obj),$(GLSOBJS)) \ |
| 32 | $(addprefix $(obj),$(GLCOBJS)) |
| 33 | |
| 34 | ## But only build it if the user asked for it |
| 35 | ifdef USE_PRIVATE_LIBGCC |
| 36 | TARGETS += $(LIBGCC) |
| 37 | endif |
| 38 | |
Sebastien Carlier | 6d8962e | 2010-11-05 15:48:07 +0100 | [diff] [blame] | 39 | LIB = $(obj)lib$(ARCH).o |
wdenk | 0c8959d | 2002-08-14 08:04:29 +0000 | [diff] [blame] | 40 | |
Marian Balakowicz | 823afe7 | 2008-02-27 11:00:47 +0100 | [diff] [blame] | 41 | SOBJS-y += ppccache.o |
| 42 | SOBJS-y += ppcstring.o |
| 43 | SOBJS-y += ticks.o |
Joakim Tjernlund | fc4e188 | 2010-01-19 14:41:55 +0100 | [diff] [blame] | 44 | SOBJS-y += reloc.o |
wdenk | 0c8959d | 2002-08-14 08:04:29 +0000 | [diff] [blame] | 45 | |
Peter Tyser | 4bbfd3e | 2010-10-07 22:32:48 -0500 | [diff] [blame] | 46 | COBJS-$(CONFIG_BAT_RW) += bat_rw.o |
Marian Balakowicz | 823afe7 | 2008-02-27 11:00:47 +0100 | [diff] [blame] | 47 | COBJS-y += board.o |
| 48 | COBJS-y += bootm.o |
Stefan Roese | e4a95d1 | 2010-04-28 10:47:36 +0200 | [diff] [blame] | 49 | COBJS-$(CONFIG_BOOTCOUNT_LIMIT) += bootcount.o |
Marian Balakowicz | 823afe7 | 2008-02-27 11:00:47 +0100 | [diff] [blame] | 50 | COBJS-y += cache.o |
| 51 | COBJS-y += extable.o |
| 52 | COBJS-y += interrupts.o |
Peter Tyser | 425d3b6 | 2009-11-03 23:31:07 -0600 | [diff] [blame] | 53 | COBJS-$(CONFIG_CMD_KGDB) += kgdb.o |
Marian Balakowicz | 823afe7 | 2008-02-27 11:00:47 +0100 | [diff] [blame] | 54 | COBJS-y += time.o |
wdenk | 0c8959d | 2002-08-14 08:04:29 +0000 | [diff] [blame] | 55 | |
Wolfgang Denk | 4ccd551 | 2010-06-29 01:33:35 +0200 | [diff] [blame] | 56 | # Workaround for local bus unaligned access problems |
| 57 | # on MPC512x and MPC5200 |
| 58 | ifdef CONFIG_MPC512X |
| 59 | $(obj)ppcstring.o: AFLAGS += -Dmemcpy=__memcpy |
| 60 | COBJS-y += memcpy_mpc5200.o |
| 61 | endif |
Wolfgang Denk | 460c2ce | 2010-06-21 22:29:59 +0200 | [diff] [blame] | 62 | ifdef CONFIG_MPC5200 |
| 63 | $(obj)ppcstring.o: AFLAGS += -Dmemcpy=__memcpy |
Wolfgang Denk | 4ccd551 | 2010-06-29 01:33:35 +0200 | [diff] [blame] | 64 | COBJS-y += memcpy_mpc5200.o |
Wolfgang Denk | 460c2ce | 2010-06-21 22:29:59 +0200 | [diff] [blame] | 65 | endif |
| 66 | |
Wolfgang Denk | 4ccd551 | 2010-06-29 01:33:35 +0200 | [diff] [blame] | 67 | COBJS += $(sort $(COBJS-y)) |
| 68 | |
Kyle Moffett | 01baa05 | 2011-02-23 06:40:38 +0000 | [diff] [blame] | 69 | SRCS := $(GLSOBJS:.o=.S) $(GLCOBJS:.o=.c) \ |
| 70 | $(SOBJS-y:.o=.S) $(COBJS-y:.o=.c) |
Wolfgang Denk | 4ccd551 | 2010-06-29 01:33:35 +0200 | [diff] [blame] | 71 | OBJS := $(addprefix $(obj),$(SOBJS-y) $(COBJS-y)) |
| 72 | |
Kyle Moffett | 01baa05 | 2011-02-23 06:40:38 +0000 | [diff] [blame] | 73 | TARGETS += $(LIB) |
| 74 | |
| 75 | all: $(TARGETS) |
| 76 | |
Marian Balakowicz | f932863 | 2006-09-01 19:49:50 +0200 | [diff] [blame] | 77 | $(LIB): $(obj).depend $(OBJS) |
Peter Tyser | 2446151 | 2009-09-21 11:20:26 -0500 | [diff] [blame] | 78 | @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 Carlier | 6d8962e | 2010-11-05 15:48:07 +0100 | [diff] [blame] | 84 | $(call cmd_link_o_target, $(OBJS)) |
wdenk | 0c8959d | 2002-08-14 08:04:29 +0000 | [diff] [blame] | 85 | |
Kyle Moffett | 01baa05 | 2011-02-23 06:40:38 +0000 | [diff] [blame] | 86 | $(LIBGCC): $(obj).depend $(LGOBJS) |
| 87 | $(call cmd_link_o_target, $(LGOBJS)) |
| 88 | |
wdenk | 0c8959d | 2002-08-14 08:04:29 +0000 | [diff] [blame] | 89 | ######################################################################### |
| 90 | |
Marian Balakowicz | f932863 | 2006-09-01 19:49:50 +0200 | [diff] [blame] | 91 | # defines $(obj).depend target |
| 92 | include $(SRCTREE)/rules.mk |
wdenk | 0c8959d | 2002-08-14 08:04:29 +0000 | [diff] [blame] | 93 | |
Marian Balakowicz | f932863 | 2006-09-01 19:49:50 +0200 | [diff] [blame] | 94 | sinclude $(obj).depend |
wdenk | 0c8959d | 2002-08-14 08:04:29 +0000 | [diff] [blame] | 95 | |
| 96 | ######################################################################### |