1# 2# (C) Copyright 2006 3# Wolfgang Denk, DENX Software Engineering, wd@denx.de. 4# 5# (C) Copyright 2002,2003 Motorola Inc. 6# Xianghua Xiao,X.Xiao@motorola.com 7# 8# SPDX-License-Identifier: GPL-2.0+ 9# 10 11include $(TOPDIR)/config.mk 12 13LIB = $(obj)lib$(CPU).o 14 15MINIMAL= 16 17ifdef CONFIG_SPL_BUILD 18ifdef CONFIG_SPL_INIT_MINIMAL 19MINIMAL=y 20endif 21endif 22 23START = start.o resetvec.o 24 25ifdef MINIMAL 26 27COBJS-y += cpu_init_early.o tlb.o spl_minimal.o 28 29else 30 31SOBJS-$(CONFIG_MP) += release.o 32SOBJS = $(SOBJS-y) 33 34COBJS-$(CONFIG_CMD_ERRATA) += cmd_errata.o 35COBJS-$(CONFIG_CPM2) += commproc.o 36 37# supports ddr1 38COBJS-$(CONFIG_MPC8540) += ddr-gen1.o 39COBJS-$(CONFIG_MPC8560) += ddr-gen1.o 40COBJS-$(CONFIG_MPC8541) += ddr-gen1.o 41COBJS-$(CONFIG_MPC8555) += ddr-gen1.o 42 43# supports ddr1/2 44COBJS-$(CONFIG_MPC8548) += ddr-gen2.o 45COBJS-$(CONFIG_MPC8568) += ddr-gen2.o 46COBJS-$(CONFIG_MPC8544) += ddr-gen2.o 47 48# supports ddr1/2/3 49COBJS-$(CONFIG_MPC8572) += ddr-gen3.o 50COBJS-$(CONFIG_MPC8536) += ddr-gen3.o 51COBJS-$(CONFIG_MPC8569) += ddr-gen3.o 52COBJS-$(CONFIG_P1010) += ddr-gen3.o 53COBJS-$(CONFIG_P1011) += ddr-gen3.o 54COBJS-$(CONFIG_P1012) += ddr-gen3.o 55COBJS-$(CONFIG_P1013) += ddr-gen3.o 56COBJS-$(CONFIG_P1014) += ddr-gen3.o 57COBJS-$(CONFIG_P1020) += ddr-gen3.o 58COBJS-$(CONFIG_P1021) += ddr-gen3.o 59COBJS-$(CONFIG_P1022) += ddr-gen3.o 60COBJS-$(CONFIG_P1023) += ddr-gen3.o 61COBJS-$(CONFIG_P1024) += ddr-gen3.o 62COBJS-$(CONFIG_P1025) += ddr-gen3.o 63COBJS-$(CONFIG_P2010) += ddr-gen3.o 64COBJS-$(CONFIG_P2020) += ddr-gen3.o 65COBJS-$(CONFIG_PPC_P2041) += ddr-gen3.o 66COBJS-$(CONFIG_PPC_P3041) += ddr-gen3.o 67COBJS-$(CONFIG_PPC_P4080) += ddr-gen3.o 68COBJS-$(CONFIG_PPC_P5020) += ddr-gen3.o 69COBJS-$(CONFIG_PPC_P5040) += ddr-gen3.o 70COBJS-$(CONFIG_PPC_T4240) += ddr-gen3.o 71COBJS-$(CONFIG_PPC_T4160) += ddr-gen3.o 72COBJS-$(CONFIG_PPC_B4420) += ddr-gen3.o 73COBJS-$(CONFIG_PPC_B4860) += ddr-gen3.o 74COBJS-$(CONFIG_BSC9131) += ddr-gen3.o 75COBJS-$(CONFIG_BSC9132) += ddr-gen3.o 76COBJS-$(CONFIG_PPC_T1040) += ddr-gen3.o 77 78COBJS-$(CONFIG_CPM2) += ether_fcc.o 79COBJS-$(CONFIG_OF_LIBFDT) += fdt.o 80COBJS-$(CONFIG_FSL_CORENET) += liodn.o 81COBJS-$(CONFIG_MP) += mp.o 82COBJS-$(CONFIG_PCI) += pci.o 83COBJS-$(CONFIG_SYS_DPAA_QBMAN) += portals.o 84 85# various SoC specific assignments 86COBJS-$(CONFIG_PPC_P2041) += p2041_ids.o 87COBJS-$(CONFIG_PPC_P3041) += p3041_ids.o 88COBJS-$(CONFIG_PPC_P4080) += p4080_ids.o 89COBJS-$(CONFIG_PPC_P5020) += p5020_ids.o 90COBJS-$(CONFIG_PPC_P5040) += p5040_ids.o 91COBJS-$(CONFIG_PPC_T4240) += t4240_ids.o 92COBJS-$(CONFIG_PPC_T4160) += t4240_ids.o 93COBJS-$(CONFIG_PPC_B4420) += b4860_ids.o 94COBJS-$(CONFIG_PPC_B4860) += b4860_ids.o 95COBJS-$(CONFIG_PPC_T1040) += t1040_ids.o 96 97COBJS-$(CONFIG_QE) += qe_io.o 98COBJS-$(CONFIG_CPM2) += serial_scc.o 99COBJS-$(CONFIG_SYS_FSL_QORIQ_CHASSIS1) += fsl_corenet_serdes.o 100COBJS-$(CONFIG_SYS_FSL_QORIQ_CHASSIS2) += fsl_corenet2_serdes.o 101 102# SoC specific SERDES support 103COBJS-$(CONFIG_MPC8536) += mpc8536_serdes.o 104COBJS-$(CONFIG_MPC8544) += mpc8544_serdes.o 105COBJS-$(CONFIG_MPC8548) += mpc8548_serdes.o 106COBJS-$(CONFIG_MPC8568) += mpc8568_serdes.o 107COBJS-$(CONFIG_MPC8569) += mpc8569_serdes.o 108COBJS-$(CONFIG_MPC8572) += mpc8572_serdes.o 109COBJS-$(CONFIG_P1010) += p1010_serdes.o 110COBJS-$(CONFIG_P1011) += p1021_serdes.o 111COBJS-$(CONFIG_P1012) += p1021_serdes.o 112COBJS-$(CONFIG_P1013) += p1022_serdes.o 113COBJS-$(CONFIG_P1014) += p1010_serdes.o 114COBJS-$(CONFIG_P1017) += p1023_serdes.o 115COBJS-$(CONFIG_P1020) += p1021_serdes.o 116COBJS-$(CONFIG_P1021) += p1021_serdes.o 117COBJS-$(CONFIG_P1022) += p1022_serdes.o 118COBJS-$(CONFIG_P1023) += p1023_serdes.o 119COBJS-$(CONFIG_P1024) += p1021_serdes.o 120COBJS-$(CONFIG_P1025) += p1021_serdes.o 121COBJS-$(CONFIG_P2010) += p2020_serdes.o 122COBJS-$(CONFIG_P2020) += p2020_serdes.o 123COBJS-$(CONFIG_PPC_P2041) += p2041_serdes.o 124COBJS-$(CONFIG_PPC_P3041) += p3041_serdes.o 125COBJS-$(CONFIG_PPC_P4080) += p4080_serdes.o 126COBJS-$(CONFIG_PPC_P5020) += p5020_serdes.o 127COBJS-$(CONFIG_PPC_P5040) += p5040_serdes.o 128COBJS-$(CONFIG_PPC_T4240) += t4240_serdes.o 129COBJS-$(CONFIG_PPC_T4160) += t4240_serdes.o 130COBJS-$(CONFIG_PPC_B4420) += b4860_serdes.o 131COBJS-$(CONFIG_PPC_B4860) += b4860_serdes.o 132COBJS-$(CONFIG_BSC9132) += bsc9132_serdes.o 133COBJS-$(CONFIG_PPC_T1040) += t1040_serdes.o 134 135COBJS-y += cpu.o 136COBJS-y += cpu_init.o 137COBJS-y += cpu_init_early.o 138COBJS-y += interrupts.o 139COBJS-y += speed.o 140COBJS-y += tlb.o 141COBJS-y += traps.o 142 143# Stub implementations of cache management functions for USB 144COBJS-y += cache.o 145 146endif # not minimal 147 148COBJS = $(COBJS-y) 149 150SRCS := $(START:.o=.S) $(SOBJS:.o=.S) $(COBJS:.o=.c) 151OBJS := $(addprefix $(obj),$(SOBJS) $(COBJS)) 152START := $(addprefix $(obj),$(START)) 153 154all: $(obj).depend $(START) $(LIB) 155 156$(LIB): $(OBJS) 157 $(call cmd_link_o_target, $(OBJS)) 158 159######################################################################### 160 161# defines $(obj).depend target 162include $(SRCTREE)/rules.mk 163 164sinclude $(obj).depend 165 166######################################################################### 167