xref: /openbmc/linux/arch/arm/mach-omap2/Makefile (revision f8e17c17)
1# SPDX-License-Identifier: GPL-2.0
2#
3# Makefile for the linux kernel.
4#
5
6ccflags-y := -I$(srctree)/$(src)/include \
7	-I$(srctree)/arch/arm/plat-omap/include
8
9# Common support
10obj-y := id.o io.o control.o devices.o fb.o timer.o pm.o \
11	 common.o dma.o wd_timer.o display.o i2c.o hdq1w.o omap_hwmod.o \
12	 omap_device.o omap-headsmp.o sram.o
13
14hwmod-common				= omap_hwmod.o omap_hwmod_reset.o \
15					  omap_hwmod_common_data.o
16clock-common				= clock.o
17secure-common				= omap-smc.o omap-secure.o
18
19obj-$(CONFIG_ARCH_OMAP2) += $(omap-2-3-common) $(hwmod-common) $(secure-common)
20obj-$(CONFIG_ARCH_OMAP3) += $(omap-2-3-common) $(hwmod-common) $(secure-common)
21obj-$(CONFIG_ARCH_OMAP4) += $(hwmod-common) $(secure-common)
22obj-$(CONFIG_SOC_AM33XX) += $(hwmod-common) $(secure-common)
23obj-$(CONFIG_SOC_OMAP5)  += $(hwmod-common) $(secure-common)
24obj-$(CONFIG_SOC_AM43XX) += $(hwmod-common) $(secure-common)
25obj-$(CONFIG_SOC_DRA7XX) += $(hwmod-common) $(secure-common)
26
27ifneq ($(CONFIG_SND_SOC_OMAP_MCBSP),)
28obj-y += mcbsp.o
29endif
30
31obj-$(CONFIG_TWL4030_CORE) += omap_twl.o
32
33ifneq ($(CONFIG_MFD_CPCAP),)
34obj-y 					+= pmic-cpcap.o
35endif
36
37obj-$(CONFIG_SOC_HAS_OMAP2_SDRC)	+= sdrc.o
38
39# SMP support ONLY available for OMAP4
40
41smp-$(CONFIG_SMP)			+= omap-smp.o
42smp-$(CONFIG_HOTPLUG_CPU)		+= omap-hotplug.o
43omap-4-5-common				=  omap4-common.o omap-wakeupgen.o
44obj-$(CONFIG_ARCH_OMAP4)		+= $(omap-4-5-common) $(smp-y) sleep44xx.o
45obj-$(CONFIG_SOC_OMAP5)			+= $(omap-4-5-common) $(smp-y) sleep44xx.o
46obj-$(CONFIG_SOC_AM43XX)		+= $(omap-4-5-common)
47obj-$(CONFIG_SOC_DRA7XX)		+= $(omap-4-5-common) $(smp-y) sleep44xx.o
48
49# Functions loaded to SRAM
50obj-$(CONFIG_SOC_OMAP2420)		+= sram242x.o
51obj-$(CONFIG_SOC_OMAP2430)		+= sram243x.o
52
53# Restart code (OMAP4/5 currently in omap4-common.c)
54obj-$(CONFIG_SOC_OMAP2420)		+= omap2-restart.o
55obj-$(CONFIG_SOC_OMAP2430)		+= omap2-restart.o
56obj-$(CONFIG_SOC_TI81XX)		+= ti81xx-restart.o
57obj-$(CONFIG_SOC_AM33XX)		+= am33xx-restart.o
58obj-$(CONFIG_SOC_AM43XX)		+= omap4-restart.o
59obj-$(CONFIG_ARCH_OMAP3)		+= omap3-restart.o
60obj-$(CONFIG_ARCH_OMAP4)		+= omap4-restart.o
61obj-$(CONFIG_SOC_OMAP5)			+= omap4-restart.o
62obj-$(CONFIG_SOC_DRA7XX)		+= omap4-restart.o
63
64# SMS/SDRC
65obj-$(CONFIG_ARCH_OMAP2)		+= sdrc2xxx.o
66# obj-$(CONFIG_ARCH_OMAP3)		+= sdrc3xxx.o
67
68# OPP table initialization
69ifeq ($(CONFIG_PM_OPP),y)
70obj-$(CONFIG_ARCH_OMAP3)		+= opp3xxx_data.o
71obj-$(CONFIG_ARCH_OMAP4)		+= opp4xxx_data.o
72endif
73
74# Power Management
75omap-4-5-pm-common			= omap-mpuss-lowpower.o
76obj-$(CONFIG_ARCH_OMAP4)		+= $(omap-4-5-pm-common)
77obj-$(CONFIG_SOC_OMAP5)			+= $(omap-4-5-pm-common)
78
79ifeq ($(CONFIG_PM),y)
80obj-$(CONFIG_ARCH_OMAP2)		+= pm24xx.o
81obj-$(CONFIG_ARCH_OMAP2)		+= sleep24xx.o
82obj-$(CONFIG_ARCH_OMAP3)		+= pm34xx.o sleep34xx.o
83omap-4-5-pm-common			+= pm44xx.o
84obj-$(CONFIG_ARCH_OMAP4)		+= $(omap-4-5-pm-common)
85obj-$(CONFIG_SOC_OMAP5)			+= $(omap-4-5-pm-common)
86obj-$(CONFIG_SOC_DRA7XX)		+= $(omap-4-5-pm-common)
87obj-$(CONFIG_SOC_AM33XX)		+= pm33xx-core.o sleep33xx.o
88obj-$(CONFIG_SOC_AM43XX)		+= pm33xx-core.o sleep43xx.o
89obj-$(CONFIG_PM_DEBUG)			+= pm-debug.o
90
91obj-$(CONFIG_POWER_AVS_OMAP)		+= sr_device.o
92obj-$(CONFIG_POWER_AVS_OMAP_CLASS3)    += smartreflex-class3.o
93
94endif
95
96ifeq ($(CONFIG_CPU_IDLE),y)
97obj-$(CONFIG_ARCH_OMAP3)                += cpuidle34xx.o
98omap-4-5-idle-common			=  cpuidle44xx.o
99obj-$(CONFIG_ARCH_OMAP4)		+= $(omap-4-5-idle-common)
100obj-$(CONFIG_SOC_OMAP5)			+= $(omap-4-5-idle-common)
101obj-$(CONFIG_SOC_DRA7XX)		+= $(omap-4-5-idle-common)
102endif
103
104# PRCM
105obj-y					+= prm_common.o cm_common.o
106obj-$(CONFIG_ARCH_OMAP2)		+= prm2xxx_3xxx.o prm2xxx.o cm2xxx.o
107obj-$(CONFIG_ARCH_OMAP3)		+= prm2xxx_3xxx.o prm3xxx.o cm3xxx.o
108obj-$(CONFIG_ARCH_OMAP3)		+= vc3xxx_data.o vp3xxx_data.o
109omap-prcm-4-5-common			=  cminst44xx.o prm44xx.o \
110					   prcm_mpu44xx.o prminst44xx.o \
111					   vc44xx_data.o vp44xx_data.o
112obj-$(CONFIG_ARCH_OMAP4)		+= $(omap-prcm-4-5-common)
113obj-$(CONFIG_SOC_OMAP5)			+= $(omap-prcm-4-5-common)
114obj-$(CONFIG_SOC_DRA7XX)		+= $(omap-prcm-4-5-common)
115am33xx-43xx-prcm-common			+= prm33xx.o cm33xx.o
116obj-$(CONFIG_SOC_TI81XX)		+= $(am33xx-43xx-prcm-common)
117obj-$(CONFIG_SOC_AM33XX)		+= $(am33xx-43xx-prcm-common)
118obj-$(CONFIG_SOC_AM43XX)		+= $(omap-prcm-4-5-common) \
119					   $(am33xx-43xx-prcm-common)
120
121# OMAP voltage domains
122voltagedomain-common			:= voltage.o vc.o vp.o
123obj-$(CONFIG_ARCH_OMAP2)		+= $(voltagedomain-common)
124obj-$(CONFIG_ARCH_OMAP2)		+= voltagedomains2xxx_data.o
125obj-$(CONFIG_ARCH_OMAP3)		+= $(voltagedomain-common)
126obj-$(CONFIG_ARCH_OMAP3)		+= voltagedomains3xxx_data.o
127obj-$(CONFIG_ARCH_OMAP4)		+= $(voltagedomain-common)
128obj-$(CONFIG_ARCH_OMAP4)		+= voltagedomains44xx_data.o
129obj-$(CONFIG_SOC_AM33XX)		+= $(voltagedomain-common)
130obj-$(CONFIG_SOC_AM43XX)		+= $(voltagedomain-common)
131obj-$(CONFIG_SOC_OMAP5)			+= $(voltagedomain-common)
132obj-$(CONFIG_SOC_OMAP5)                += voltagedomains54xx_data.o
133obj-$(CONFIG_SOC_DRA7XX)		+= $(voltagedomain-common)
134
135# OMAP powerdomain framework
136powerdomain-common			+= powerdomain.o powerdomain-common.o
137obj-$(CONFIG_ARCH_OMAP2)		+= $(powerdomain-common)
138obj-$(CONFIG_ARCH_OMAP2)		+= powerdomains2xxx_data.o
139obj-$(CONFIG_ARCH_OMAP2)		+= powerdomains2xxx_3xxx_data.o
140obj-$(CONFIG_ARCH_OMAP3)		+= $(powerdomain-common)
141obj-$(CONFIG_ARCH_OMAP3)		+= powerdomains3xxx_data.o
142obj-$(CONFIG_ARCH_OMAP3)		+= powerdomains2xxx_3xxx_data.o
143obj-$(CONFIG_ARCH_OMAP4)		+= $(powerdomain-common)
144obj-$(CONFIG_ARCH_OMAP4)		+= powerdomains44xx_data.o
145obj-$(CONFIG_SOC_AM33XX)		+= $(powerdomain-common)
146obj-$(CONFIG_SOC_AM33XX)		+= powerdomains33xx_data.o
147obj-$(CONFIG_SOC_AM43XX)		+= $(powerdomain-common)
148obj-$(CONFIG_SOC_AM43XX)		+= powerdomains43xx_data.o
149obj-$(CONFIG_SOC_OMAP5)			+= $(powerdomain-common)
150obj-$(CONFIG_SOC_OMAP5)			+= powerdomains54xx_data.o
151obj-$(CONFIG_SOC_DRA7XX)		+= $(powerdomain-common)
152obj-$(CONFIG_SOC_DRA7XX)		+= powerdomains7xx_data.o
153
154# PRCM clockdomain control
155clockdomain-common			+= clockdomain.o
156obj-$(CONFIG_ARCH_OMAP2)		+= $(clockdomain-common)
157obj-$(CONFIG_ARCH_OMAP2)		+= clockdomains2xxx_3xxx_data.o
158obj-$(CONFIG_SOC_OMAP2420)		+= clockdomains2420_data.o
159obj-$(CONFIG_SOC_OMAP2430)		+= clockdomains2430_data.o
160obj-$(CONFIG_ARCH_OMAP3)		+= $(clockdomain-common)
161obj-$(CONFIG_ARCH_OMAP3)		+= clockdomains2xxx_3xxx_data.o
162obj-$(CONFIG_ARCH_OMAP3)		+= clockdomains3xxx_data.o
163obj-$(CONFIG_ARCH_OMAP4)		+= $(clockdomain-common)
164obj-$(CONFIG_ARCH_OMAP4)		+= clockdomains44xx_data.o
165obj-$(CONFIG_SOC_AM33XX)		+= $(clockdomain-common)
166obj-$(CONFIG_SOC_AM33XX)		+= clockdomains33xx_data.o
167obj-$(CONFIG_SOC_TI81XX)		+= $(clockdomain-common)
168obj-$(CONFIG_SOC_TI81XX)		+= clockdomains81xx_data.o
169obj-$(CONFIG_SOC_AM43XX)		+= $(clockdomain-common)
170obj-$(CONFIG_SOC_AM43XX)		+= clockdomains43xx_data.o
171obj-$(CONFIG_SOC_OMAP5)			+= $(clockdomain-common)
172obj-$(CONFIG_SOC_OMAP5)			+= clockdomains54xx_data.o
173obj-$(CONFIG_SOC_DRA7XX)		+= $(clockdomain-common)
174obj-$(CONFIG_SOC_DRA7XX)		+= clockdomains7xx_data.o
175
176# Clock framework
177obj-$(CONFIG_ARCH_OMAP2)		+= $(clock-common)
178obj-$(CONFIG_ARCH_OMAP2)		+= clkt2xxx_dpllcore.o
179obj-$(CONFIG_ARCH_OMAP2)		+= clkt2xxx_virt_prcm_set.o
180obj-$(CONFIG_ARCH_OMAP2)		+= clkt2xxx_dpll.o
181obj-$(CONFIG_ARCH_OMAP3)		+= $(clock-common)
182obj-$(CONFIG_ARCH_OMAP4)		+= $(clock-common)
183obj-$(CONFIG_SOC_AM33XX)		+= $(clock-common)
184obj-$(CONFIG_SOC_OMAP5)			+= $(clock-common)
185obj-$(CONFIG_SOC_DRA7XX)		+= $(clock-common)
186obj-$(CONFIG_SOC_AM43XX)		+= $(clock-common)
187
188# OMAP2 clock rate set data (old "OPP" data)
189obj-$(CONFIG_SOC_OMAP2420)		+= opp2420_data.o
190obj-$(CONFIG_SOC_OMAP2430)		+= opp2430_data.o
191
192# hwmod data
193obj-y					+= omap_hwmod_common_ipblock_data.o
194obj-$(CONFIG_SOC_OMAP2420)		+= omap_hwmod_2xxx_ipblock_data.o
195obj-$(CONFIG_SOC_OMAP2420)		+= omap_hwmod_2xxx_3xxx_ipblock_data.o
196obj-$(CONFIG_SOC_OMAP2420)		+= omap_hwmod_2xxx_interconnect_data.o
197obj-$(CONFIG_SOC_OMAP2420)		+= omap_hwmod_2420_data.o
198obj-$(CONFIG_SOC_OMAP2430)		+= omap_hwmod_2xxx_ipblock_data.o
199obj-$(CONFIG_SOC_OMAP2430)		+= omap_hwmod_2xxx_3xxx_ipblock_data.o
200obj-$(CONFIG_SOC_OMAP2430)		+= omap_hwmod_2xxx_interconnect_data.o
201obj-$(CONFIG_SOC_OMAP2430)		+= omap_hwmod_2430_data.o
202obj-$(CONFIG_ARCH_OMAP3)		+= omap_hwmod_2xxx_3xxx_ipblock_data.o
203obj-$(CONFIG_ARCH_OMAP3)		+= omap_hwmod_3xxx_data.o
204obj-$(CONFIG_SOC_AM33XX)		+= omap_hwmod_33xx_data.o
205obj-$(CONFIG_SOC_AM33XX)		+= omap_hwmod_33xx_43xx_interconnect_data.o
206obj-$(CONFIG_SOC_AM33XX)		+= omap_hwmod_33xx_43xx_ipblock_data.o
207obj-$(CONFIG_SOC_AM43XX)		+= omap_hwmod_43xx_data.o
208obj-$(CONFIG_SOC_AM43XX)		+= omap_hwmod_33xx_43xx_interconnect_data.o
209obj-$(CONFIG_SOC_AM43XX)		+= omap_hwmod_33xx_43xx_ipblock_data.o
210obj-$(CONFIG_SOC_TI81XX)		+= omap_hwmod_81xx_data.o
211obj-$(CONFIG_ARCH_OMAP4)		+= omap_hwmod_44xx_data.o
212obj-$(CONFIG_SOC_OMAP5)			+= omap_hwmod_54xx_data.o
213obj-$(CONFIG_SOC_DRA7XX)		+= omap_hwmod_7xx_data.o
214
215# OMAP2420 MSDI controller integration support ("MMC")
216obj-$(CONFIG_SOC_OMAP2420)		+= msdi.o
217
218# Specific board support
219obj-$(CONFIG_MACH_OMAP_GENERIC)		+= board-generic.o pdata-quirks.o
220obj-$(CONFIG_MACH_NOKIA_N8X0)		+= board-n8x0.o
221
222# Platform specific device init code
223
224obj-y					+= omap_phy_internal.o
225
226obj-$(CONFIG_MACH_OMAP2_TUSB6010)	+= usb-tusb6010.o
227
228$(obj)/pm-asm-offsets.h: $(obj)/pm-asm-offsets.s FORCE
229	$(call filechk,offsets,__TI_PM_ASM_OFFSETS_H__)
230
231$(obj)/sleep33xx.o $(obj)/sleep43xx.o: $(obj)/pm-asm-offsets.h
232
233targets += pm-asm-offsets.s
234clean-files += pm-asm-offsets.h
235
236obj-$(CONFIG_OMAP_IOMMU)		+= omap-iommu.o
237