blob: 95994d38d684c1f90f54a9e89c3abcaff3071bf2 [file] [log] [blame]
wdenk9c53f402003-10-15 23:53:47 +00001#
Marian Balakowiczd62379d2006-09-01 19:49:50 +02002# (C) Copyright 2006
3# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
4#
wdenk9c53f402003-10-15 23:53:47 +00005# (C) Copyright 2002,2003 Motorola Inc.
6# Xianghua Xiao,X.Xiao@motorola.com
7#
8# See file CREDITS for list of people who contributed to this
9# project.
10#
11# This program is free software; you can redistribute it and/or
12# modify it under the terms of the GNU General Public License as
13# published by the Free Software Foundation; either version 2 of
14# the License, or (at your option) any later version.
15#
16# This program is distributed in the hope that it will be useful,
17# but WITHOUT ANY WARRANTY; without even the implied warranty of
18# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19# GNU General Public License for more details.
20#
21# You should have received a copy of the GNU General Public License
22# along with this program; if not, write to the Free Software
23# Foundation, Inc., 59 Temple Place, Suite 330, Boston,
24# MA 02111-1307 USA
25#
26
27include $(TOPDIR)/config.mk
28
Sebastien Carliera8d426f2010-11-05 15:48:07 +010029LIB = $(obj)lib$(CPU).o
wdenk9c53f402003-10-15 23:53:47 +000030
Scott Wood7c810902012-09-20 16:35:21 -050031MINIMAL=
32
33ifdef CONFIG_SPL_BUILD
34ifdef CONFIG_SPL_INIT_MINIMAL
35MINIMAL=y
36endif
37endif
38
39START = start.o resetvec.o
40
41ifdef MINIMAL
42
43COBJS-y += cpu_init_early.o tlb.o spl_minimal.o
44
45else
46
Kumar Gala591ac072009-09-02 09:00:50 -050047SOBJS-$(CONFIG_MP) += release.o
Kumar Gala36d6b3f2008-01-17 16:48:33 -060048SOBJS = $(SOBJS-y)
Kumar Gala591ac072009-09-02 09:00:50 -050049
Kumar Gala5900ea72010-06-09 22:59:41 -050050COBJS-$(CONFIG_CMD_ERRATA) += cmd_errata.o
Kumar Gala591ac072009-09-02 09:00:50 -050051COBJS-$(CONFIG_CPM2) += commproc.o
Kumar Gala124b0822008-08-26 15:01:29 -050052
Kumar Galad5a1fb92008-08-26 21:34:55 -050053# supports ddr1
Kumar Galad5a1fb92008-08-26 21:34:55 -050054COBJS-$(CONFIG_MPC8540) += ddr-gen1.o
55COBJS-$(CONFIG_MPC8560) += ddr-gen1.o
56COBJS-$(CONFIG_MPC8541) += ddr-gen1.o
57COBJS-$(CONFIG_MPC8555) += ddr-gen1.o
Kumar Galad5a1fb92008-08-26 21:34:55 -050058
59# supports ddr1/2
Kumar Galad5a1fb92008-08-26 21:34:55 -050060COBJS-$(CONFIG_MPC8548) += ddr-gen2.o
61COBJS-$(CONFIG_MPC8568) += ddr-gen2.o
62COBJS-$(CONFIG_MPC8544) += ddr-gen2.o
63
64# supports ddr1/2/3
65COBJS-$(CONFIG_MPC8572) += ddr-gen3.o
66COBJS-$(CONFIG_MPC8536) += ddr-gen3.o
Haiying Wangc9849132009-03-27 17:02:44 -040067COBJS-$(CONFIG_MPC8569) += ddr-gen3.o
Poonam Aggrwal2ba3ee02011-01-13 21:39:27 +053068COBJS-$(CONFIG_P1010) += ddr-gen3.o
Poonam Aggrwal13e21b12009-08-20 18:57:45 +053069COBJS-$(CONFIG_P1011) += ddr-gen3.o
Kumar Gala16a276e2010-03-30 23:06:53 -050070COBJS-$(CONFIG_P1012) += ddr-gen3.o
71COBJS-$(CONFIG_P1013) += ddr-gen3.o
Poonam Aggrwalb07a7de2011-01-13 21:40:05 +053072COBJS-$(CONFIG_P1014) += ddr-gen3.o
Poonam Aggrwaldfe86a72009-07-31 12:08:27 +053073COBJS-$(CONFIG_P1020) += ddr-gen3.o
Kumar Gala16a276e2010-03-30 23:06:53 -050074COBJS-$(CONFIG_P1021) += ddr-gen3.o
75COBJS-$(CONFIG_P1022) += ddr-gen3.o
Kumar Galae4e69252011-02-05 13:45:07 -060076COBJS-$(CONFIG_P1024) += ddr-gen3.o
77COBJS-$(CONFIG_P1025) += ddr-gen3.o
Poonam Aggrwal13e21b12009-08-20 18:57:45 +053078COBJS-$(CONFIG_P2010) += ddr-gen3.o
79COBJS-$(CONFIG_P2020) += ddr-gen3.o
Kumar Gala619541b2011-05-13 01:16:07 -050080COBJS-$(CONFIG_PPC_P2041) += ddr-gen3.o
Kumar Galaf2134b82010-01-27 10:26:46 -060081COBJS-$(CONFIG_PPC_P3041) += ddr-gen3.o
Kumar Galabb5409c2009-03-19 02:39:17 -050082COBJS-$(CONFIG_PPC_P4080) += ddr-gen3.o
Kumar Gala7ee3d942009-10-21 13:32:58 -050083COBJS-$(CONFIG_PPC_P5020) += ddr-gen3.o
Timur Tabid5e13882012-10-05 11:09:19 +000084COBJS-$(CONFIG_PPC_P5040) += ddr-gen3.o
York Sun9941a222012-10-08 07:44:19 +000085COBJS-$(CONFIG_PPC_T4240) += ddr-gen3.o
Poonam Aggrwal248865e2012-12-23 19:24:16 +000086COBJS-$(CONFIG_PPC_B4420) += ddr-gen3.o
York Sunbcf7b3d2012-10-08 07:44:20 +000087COBJS-$(CONFIG_PPC_B4860) += ddr-gen3.o
Prabhakar Kushwahabeebb882012-04-24 20:16:49 +000088COBJS-$(CONFIG_BSC9131) += ddr-gen3.o
Kumar Gala124b0822008-08-26 15:01:29 -050089
Kumar Gala591ac072009-09-02 09:00:50 -050090COBJS-$(CONFIG_CPM2) += ether_fcc.o
91COBJS-$(CONFIG_OF_LIBFDT) += fdt.o
Kumar Gala38449a42009-09-10 03:02:13 -050092COBJS-$(CONFIG_FSL_CORENET) += liodn.o
Kumar Gala591ac072009-09-02 09:00:50 -050093COBJS-$(CONFIG_MP) += mp.o
Kumar Gala591ac072009-09-02 09:00:50 -050094COBJS-$(CONFIG_PCI) += pci.o
Haiying Wang325a12f2011-01-20 22:26:31 +000095COBJS-$(CONFIG_SYS_DPAA_QBMAN) += portals.o
Kumar Gala38449a42009-09-10 03:02:13 -050096
97# various SoC specific assignments
Kumar Gala2c76efa2011-07-21 00:20:19 -050098COBJS-$(CONFIG_PPC_P2041) += p2041_ids.o
Kumar Galae378ae12010-07-04 13:07:08 -050099COBJS-$(CONFIG_PPC_P3041) += p3041_ids.o
Kumar Gala38449a42009-09-10 03:02:13 -0500100COBJS-$(CONFIG_PPC_P4080) += p4080_ids.o
Kumar Galacdbe63d2010-07-08 05:24:44 -0500101COBJS-$(CONFIG_PPC_P5020) += p5020_ids.o
Timur Tabid5e13882012-10-05 11:09:19 +0000102COBJS-$(CONFIG_PPC_P5040) += p5040_ids.o
York Sun9941a222012-10-08 07:44:19 +0000103COBJS-$(CONFIG_PPC_T4240) += t4240_ids.o
Poonam Aggrwal248865e2012-12-23 19:24:16 +0000104COBJS-$(CONFIG_PPC_B4420) += b4860_ids.o
York Sunbcf7b3d2012-10-08 07:44:20 +0000105COBJS-$(CONFIG_PPC_B4860) += b4860_ids.o
Kumar Gala38449a42009-09-10 03:02:13 -0500106
Kumar Gala591ac072009-09-02 09:00:50 -0500107COBJS-$(CONFIG_QE) += qe_io.o
108COBJS-$(CONFIG_CPM2) += serial_scc.o
York Sun7e0edbd2012-10-08 07:44:15 +0000109COBJS-$(CONFIG_SYS_FSL_QORIQ_CHASSIS1) += fsl_corenet_serdes.o
110COBJS-$(CONFIG_SYS_FSL_QORIQ_CHASSIS2) += fsl_corenet2_serdes.o
Kumar Galae5f2ef72010-12-15 04:07:55 -0600111
112# SoC specific SERDES support
113COBJS-$(CONFIG_MPC8536) += mpc8536_serdes.o
Kumar Gala4887c702010-04-27 09:20:20 -0500114COBJS-$(CONFIG_MPC8544) += mpc8544_serdes.o
Kumar Gala3bdd04d2010-04-26 23:25:33 -0500115COBJS-$(CONFIG_MPC8548) += mpc8548_serdes.o
Kumar Gala29e789e2010-04-26 23:44:10 -0500116COBJS-$(CONFIG_MPC8568) += mpc8568_serdes.o
Kumar Gala1c1fe932010-04-27 00:05:41 -0500117COBJS-$(CONFIG_MPC8569) += mpc8569_serdes.o
Kumar Gala87ead052010-04-26 23:09:23 -0500118COBJS-$(CONFIG_MPC8572) += mpc8572_serdes.o
Prabhakar Kushwaha934e6ed2011-01-20 16:34:41 +0530119COBJS-$(CONFIG_P1010) += p1010_serdes.o
Kumar Gala54e12db2010-12-15 04:04:56 -0600120COBJS-$(CONFIG_P1011) += p1021_serdes.o
121COBJS-$(CONFIG_P1012) += p1021_serdes.o
Kumar Gala52ed8b32011-02-04 12:50:53 -0600122COBJS-$(CONFIG_P1013) += p1022_serdes.o
Prabhakar Kushwaha934e6ed2011-01-20 16:34:41 +0530123COBJS-$(CONFIG_P1014) += p1010_serdes.o
Roy Zang1de20b02011-02-03 22:14:19 -0600124COBJS-$(CONFIG_P1017) += p1023_serdes.o
Kumar Gala54e12db2010-12-15 04:04:56 -0600125COBJS-$(CONFIG_P1020) += p1021_serdes.o
126COBJS-$(CONFIG_P1021) += p1021_serdes.o
Kumar Galae5f2ef72010-12-15 04:07:55 -0600127COBJS-$(CONFIG_P1022) += p1022_serdes.o
Roy Zang1de20b02011-02-03 22:14:19 -0600128COBJS-$(CONFIG_P1023) += p1023_serdes.o
Kumar Galae4e69252011-02-05 13:45:07 -0600129COBJS-$(CONFIG_P1024) += p1021_serdes.o
130COBJS-$(CONFIG_P1025) += p1021_serdes.o
Kumar Gala4304b002010-12-15 02:49:03 -0600131COBJS-$(CONFIG_P2010) += p2020_serdes.o
132COBJS-$(CONFIG_P2020) += p2020_serdes.o
Kumar Gala619541b2011-05-13 01:16:07 -0500133COBJS-$(CONFIG_PPC_P2041) += p2041_serdes.o
Kumar Galae378ae12010-07-04 13:07:08 -0500134COBJS-$(CONFIG_PPC_P3041) += p3041_serdes.o
Kumar Gala674e0f42010-07-12 22:51:29 -0500135COBJS-$(CONFIG_PPC_P4080) += p4080_serdes.o
Kumar Galacdbe63d2010-07-08 05:24:44 -0500136COBJS-$(CONFIG_PPC_P5020) += p5020_serdes.o
Timur Tabid5e13882012-10-05 11:09:19 +0000137COBJS-$(CONFIG_PPC_P5040) += p5040_serdes.o
York Sun9941a222012-10-08 07:44:19 +0000138COBJS-$(CONFIG_PPC_T4240) += t4240_serdes.o
Poonam Aggrwal248865e2012-12-23 19:24:16 +0000139COBJS-$(CONFIG_PPC_B4420) += b4860_serdes.o
York Sunbcf7b3d2012-10-08 07:44:20 +0000140COBJS-$(CONFIG_PPC_B4860) += b4860_serdes.o
Kumar Gala591ac072009-09-02 09:00:50 -0500141
Scott Wood94db8d62012-09-25 18:17:45 -0500142COBJS-y += cpu.o
143COBJS-y += cpu_init.o
144COBJS-y += cpu_init_early.o
145COBJS-y += interrupts.o
146COBJS-y += speed.o
147COBJS-y += tlb.o
148COBJS-y += traps.o
wdenk9c53f402003-10-15 23:53:47 +0000149
Marek Vasut594f17e2012-05-25 16:14:46 +0200150# Stub implementations of cache management functions for USB
Scott Wood94db8d62012-09-25 18:17:45 -0500151COBJS-y += cache.o
152
Scott Wood7c810902012-09-20 16:35:21 -0500153endif # not minimal
154
Scott Wood94db8d62012-09-25 18:17:45 -0500155COBJS = $(COBJS-y)
Marek Vasut594f17e2012-05-25 16:14:46 +0200156
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200157SRCS := $(START:.o=.S) $(SOBJS:.o=.S) $(COBJS:.o=.c)
158OBJS := $(addprefix $(obj),$(SOBJS) $(COBJS))
159START := $(addprefix $(obj),$(START))
160
161all: $(obj).depend $(START) $(LIB)
wdenk9c53f402003-10-15 23:53:47 +0000162
163$(LIB): $(OBJS)
Sebastien Carliera8d426f2010-11-05 15:48:07 +0100164 $(call cmd_link_o_target, $(OBJS))
wdenk9c53f402003-10-15 23:53:47 +0000165
166#########################################################################
167
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200168# defines $(obj).depend target
169include $(SRCTREE)/rules.mk
wdenk9c53f402003-10-15 23:53:47 +0000170
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200171sinclude $(obj).depend
wdenk9c53f402003-10-15 23:53:47 +0000172
173#########################################################################