blob: 01377c292db43f6e48e7d3f4098140c7bf5cea7f [file] [log] [blame]
xjb04a4022021-11-25 15:01:52 +08001# 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)
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)
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_OMAP_SOC_MCBSP),)
28obj-y += mcbsp.o
29endif
30
31obj-$(CONFIG_TWL4030_CORE) += omap_twl.o
32obj-$(CONFIG_SOC_HAS_OMAP2_SDRC) += sdrc.o
33
34# SMP support ONLY available for OMAP4
35
36smp-$(CONFIG_SMP) += omap-smp.o
37smp-$(CONFIG_HOTPLUG_CPU) += omap-hotplug.o
38omap-4-5-common = omap4-common.o omap-wakeupgen.o
39obj-$(CONFIG_ARCH_OMAP4) += $(omap-4-5-common) $(smp-y) sleep44xx.o
40obj-$(CONFIG_SOC_OMAP5) += $(omap-4-5-common) $(smp-y) sleep44xx.o
41obj-$(CONFIG_SOC_AM43XX) += $(omap-4-5-common)
42obj-$(CONFIG_SOC_DRA7XX) += $(omap-4-5-common) $(smp-y) sleep44xx.o
43
44plus_sec := $(call as-instr,.arch_extension sec,+sec)
45AFLAGS_omap-headsmp.o :=-Wa,-march=armv7-a$(plus_sec)
46AFLAGS_omap-smc.o :=-Wa,-march=armv7-a$(plus_sec)
47AFLAGS_sleep44xx.o :=-Wa,-march=armv7-a$(plus_sec)
48
49# Functions loaded to SRAM
50obj-$(CONFIG_SOC_OMAP2420) += sram242x.o
51obj-$(CONFIG_SOC_OMAP2430) += sram243x.o
52
53AFLAGS_sram242x.o :=-Wa,-march=armv6
54AFLAGS_sram243x.o :=-Wa,-march=armv6
55
56# Restart code (OMAP4/5 currently in omap4-common.c)
57obj-$(CONFIG_SOC_OMAP2420) += omap2-restart.o
58obj-$(CONFIG_SOC_OMAP2430) += omap2-restart.o
59obj-$(CONFIG_SOC_TI81XX) += ti81xx-restart.o
60obj-$(CONFIG_SOC_AM33XX) += am33xx-restart.o
61obj-$(CONFIG_SOC_AM43XX) += omap4-restart.o
62obj-$(CONFIG_ARCH_OMAP3) += omap3-restart.o
63obj-$(CONFIG_ARCH_OMAP4) += omap4-restart.o
64obj-$(CONFIG_SOC_OMAP5) += omap4-restart.o
65obj-$(CONFIG_SOC_DRA7XX) += omap4-restart.o
66
67# SMS/SDRC
68obj-$(CONFIG_ARCH_OMAP2) += sdrc2xxx.o
69# obj-$(CONFIG_ARCH_OMAP3) += sdrc3xxx.o
70
71# OPP table initialization
72ifeq ($(CONFIG_PM_OPP),y)
73obj-$(CONFIG_ARCH_OMAP3) += opp3xxx_data.o
74obj-$(CONFIG_ARCH_OMAP4) += opp4xxx_data.o
75endif
76
77# Power Management
78omap-4-5-pm-common = omap-mpuss-lowpower.o
79obj-$(CONFIG_ARCH_OMAP4) += $(omap-4-5-pm-common)
80obj-$(CONFIG_SOC_OMAP5) += $(omap-4-5-pm-common)
81
82ifeq ($(CONFIG_PM),y)
83obj-$(CONFIG_ARCH_OMAP2) += pm24xx.o
84obj-$(CONFIG_ARCH_OMAP2) += sleep24xx.o
85obj-$(CONFIG_ARCH_OMAP3) += pm34xx.o sleep34xx.o
86omap-4-5-pm-common += pm44xx.o
87obj-$(CONFIG_ARCH_OMAP4) += $(omap-4-5-pm-common)
88obj-$(CONFIG_SOC_OMAP5) += $(omap-4-5-pm-common)
89obj-$(CONFIG_SOC_DRA7XX) += $(omap-4-5-pm-common)
90obj-$(CONFIG_SOC_AM33XX) += pm33xx-core.o sleep33xx.o
91obj-$(CONFIG_SOC_AM43XX) += pm33xx-core.o sleep43xx.o
92obj-$(CONFIG_PM_DEBUG) += pm-debug.o
93
94obj-$(CONFIG_POWER_AVS_OMAP) += sr_device.o
95obj-$(CONFIG_POWER_AVS_OMAP_CLASS3) += smartreflex-class3.o
96
97AFLAGS_sleep24xx.o :=-Wa,-march=armv6
98AFLAGS_sleep34xx.o :=-Wa,-march=armv7-a$(plus_sec)
99AFLAGS_sleep33xx.o :=-Wa,-march=armv7-a$(plus_sec)
100AFLAGS_sleep43xx.o :=-Wa,-march=armv7-a$(plus_sec)
101
102endif
103
104ifeq ($(CONFIG_CPU_IDLE),y)
105obj-$(CONFIG_ARCH_OMAP3) += cpuidle34xx.o
106omap-4-5-idle-common = cpuidle44xx.o
107obj-$(CONFIG_ARCH_OMAP4) += $(omap-4-5-idle-common)
108obj-$(CONFIG_SOC_OMAP5) += $(omap-4-5-idle-common)
109obj-$(CONFIG_SOC_DRA7XX) += $(omap-4-5-idle-common)
110endif
111
112# PRCM
113obj-y += prm_common.o cm_common.o
114obj-$(CONFIG_ARCH_OMAP2) += prm2xxx_3xxx.o prm2xxx.o cm2xxx.o
115obj-$(CONFIG_ARCH_OMAP3) += prm2xxx_3xxx.o prm3xxx.o cm3xxx.o
116obj-$(CONFIG_ARCH_OMAP3) += vc3xxx_data.o vp3xxx_data.o
117omap-prcm-4-5-common = cminst44xx.o prm44xx.o \
118 prcm_mpu44xx.o prminst44xx.o \
119 vc44xx_data.o vp44xx_data.o
120obj-$(CONFIG_ARCH_OMAP4) += $(omap-prcm-4-5-common)
121obj-$(CONFIG_SOC_OMAP5) += $(omap-prcm-4-5-common)
122obj-$(CONFIG_SOC_DRA7XX) += $(omap-prcm-4-5-common)
123am33xx-43xx-prcm-common += prm33xx.o cm33xx.o
124obj-$(CONFIG_SOC_TI81XX) += $(am33xx-43xx-prcm-common)
125obj-$(CONFIG_SOC_AM33XX) += $(am33xx-43xx-prcm-common)
126obj-$(CONFIG_SOC_AM43XX) += $(omap-prcm-4-5-common) \
127 $(am33xx-43xx-prcm-common)
128
129# OMAP voltage domains
130voltagedomain-common := voltage.o vc.o vp.o
131obj-$(CONFIG_ARCH_OMAP2) += $(voltagedomain-common)
132obj-$(CONFIG_ARCH_OMAP2) += voltagedomains2xxx_data.o
133obj-$(CONFIG_ARCH_OMAP3) += $(voltagedomain-common)
134obj-$(CONFIG_ARCH_OMAP3) += voltagedomains3xxx_data.o
135obj-$(CONFIG_ARCH_OMAP4) += $(voltagedomain-common)
136obj-$(CONFIG_ARCH_OMAP4) += voltagedomains44xx_data.o
137obj-$(CONFIG_SOC_AM33XX) += $(voltagedomain-common)
138obj-$(CONFIG_SOC_AM43XX) += $(voltagedomain-common)
139obj-$(CONFIG_SOC_OMAP5) += $(voltagedomain-common)
140obj-$(CONFIG_SOC_OMAP5) += voltagedomains54xx_data.o
141obj-$(CONFIG_SOC_DRA7XX) += $(voltagedomain-common)
142
143# OMAP powerdomain framework
144powerdomain-common += powerdomain.o powerdomain-common.o
145obj-$(CONFIG_ARCH_OMAP2) += $(powerdomain-common)
146obj-$(CONFIG_ARCH_OMAP2) += powerdomains2xxx_data.o
147obj-$(CONFIG_ARCH_OMAP2) += powerdomains2xxx_3xxx_data.o
148obj-$(CONFIG_ARCH_OMAP3) += $(powerdomain-common)
149obj-$(CONFIG_ARCH_OMAP3) += powerdomains3xxx_data.o
150obj-$(CONFIG_ARCH_OMAP3) += powerdomains2xxx_3xxx_data.o
151obj-$(CONFIG_ARCH_OMAP4) += $(powerdomain-common)
152obj-$(CONFIG_ARCH_OMAP4) += powerdomains44xx_data.o
153obj-$(CONFIG_SOC_AM33XX) += $(powerdomain-common)
154obj-$(CONFIG_SOC_AM33XX) += powerdomains33xx_data.o
155obj-$(CONFIG_SOC_AM43XX) += $(powerdomain-common)
156obj-$(CONFIG_SOC_AM43XX) += powerdomains43xx_data.o
157obj-$(CONFIG_SOC_OMAP5) += $(powerdomain-common)
158obj-$(CONFIG_SOC_OMAP5) += powerdomains54xx_data.o
159obj-$(CONFIG_SOC_DRA7XX) += $(powerdomain-common)
160obj-$(CONFIG_SOC_DRA7XX) += powerdomains7xx_data.o
161
162# PRCM clockdomain control
163clockdomain-common += clockdomain.o
164obj-$(CONFIG_ARCH_OMAP2) += $(clockdomain-common)
165obj-$(CONFIG_ARCH_OMAP2) += clockdomains2xxx_3xxx_data.o
166obj-$(CONFIG_SOC_OMAP2420) += clockdomains2420_data.o
167obj-$(CONFIG_SOC_OMAP2430) += clockdomains2430_data.o
168obj-$(CONFIG_ARCH_OMAP3) += $(clockdomain-common)
169obj-$(CONFIG_ARCH_OMAP3) += clockdomains2xxx_3xxx_data.o
170obj-$(CONFIG_ARCH_OMAP3) += clockdomains3xxx_data.o
171obj-$(CONFIG_ARCH_OMAP4) += $(clockdomain-common)
172obj-$(CONFIG_ARCH_OMAP4) += clockdomains44xx_data.o
173obj-$(CONFIG_SOC_AM33XX) += $(clockdomain-common)
174obj-$(CONFIG_SOC_AM33XX) += clockdomains33xx_data.o
175obj-$(CONFIG_SOC_TI81XX) += $(clockdomain-common)
176obj-$(CONFIG_SOC_TI81XX) += clockdomains81xx_data.o
177obj-$(CONFIG_SOC_AM43XX) += $(clockdomain-common)
178obj-$(CONFIG_SOC_AM43XX) += clockdomains43xx_data.o
179obj-$(CONFIG_SOC_OMAP5) += $(clockdomain-common)
180obj-$(CONFIG_SOC_OMAP5) += clockdomains54xx_data.o
181obj-$(CONFIG_SOC_DRA7XX) += $(clockdomain-common)
182obj-$(CONFIG_SOC_DRA7XX) += clockdomains7xx_data.o
183
184# Clock framework
185obj-$(CONFIG_ARCH_OMAP2) += $(clock-common)
186obj-$(CONFIG_ARCH_OMAP2) += clkt2xxx_dpllcore.o
187obj-$(CONFIG_ARCH_OMAP2) += clkt2xxx_virt_prcm_set.o
188obj-$(CONFIG_ARCH_OMAP2) += clkt2xxx_dpll.o
189obj-$(CONFIG_ARCH_OMAP3) += $(clock-common)
190obj-$(CONFIG_ARCH_OMAP4) += $(clock-common)
191obj-$(CONFIG_SOC_AM33XX) += $(clock-common)
192obj-$(CONFIG_SOC_OMAP5) += $(clock-common)
193obj-$(CONFIG_SOC_DRA7XX) += $(clock-common)
194obj-$(CONFIG_SOC_AM43XX) += $(clock-common)
195
196# OMAP2 clock rate set data (old "OPP" data)
197obj-$(CONFIG_SOC_OMAP2420) += opp2420_data.o
198obj-$(CONFIG_SOC_OMAP2430) += opp2430_data.o
199
200# hwmod data
201obj-y += omap_hwmod_common_ipblock_data.o
202obj-$(CONFIG_SOC_OMAP2420) += omap_hwmod_2xxx_ipblock_data.o
203obj-$(CONFIG_SOC_OMAP2420) += omap_hwmod_2xxx_3xxx_ipblock_data.o
204obj-$(CONFIG_SOC_OMAP2420) += omap_hwmod_2xxx_interconnect_data.o
205obj-$(CONFIG_SOC_OMAP2420) += omap_hwmod_2420_data.o
206obj-$(CONFIG_SOC_OMAP2430) += omap_hwmod_2xxx_ipblock_data.o
207obj-$(CONFIG_SOC_OMAP2430) += omap_hwmod_2xxx_3xxx_ipblock_data.o
208obj-$(CONFIG_SOC_OMAP2430) += omap_hwmod_2xxx_interconnect_data.o
209obj-$(CONFIG_SOC_OMAP2430) += omap_hwmod_2430_data.o
210obj-$(CONFIG_ARCH_OMAP3) += omap_hwmod_2xxx_3xxx_ipblock_data.o
211obj-$(CONFIG_ARCH_OMAP3) += omap_hwmod_3xxx_data.o
212obj-$(CONFIG_SOC_AM33XX) += omap_hwmod_33xx_data.o
213obj-$(CONFIG_SOC_AM33XX) += omap_hwmod_33xx_43xx_interconnect_data.o
214obj-$(CONFIG_SOC_AM33XX) += omap_hwmod_33xx_43xx_ipblock_data.o
215obj-$(CONFIG_SOC_AM43XX) += omap_hwmod_43xx_data.o
216obj-$(CONFIG_SOC_AM43XX) += omap_hwmod_33xx_43xx_interconnect_data.o
217obj-$(CONFIG_SOC_AM43XX) += omap_hwmod_33xx_43xx_ipblock_data.o
218obj-$(CONFIG_SOC_TI81XX) += omap_hwmod_81xx_data.o
219obj-$(CONFIG_ARCH_OMAP4) += omap_hwmod_44xx_data.o
220obj-$(CONFIG_SOC_OMAP5) += omap_hwmod_54xx_data.o
221obj-$(CONFIG_SOC_DRA7XX) += omap_hwmod_7xx_data.o
222
223# OMAP2420 MSDI controller integration support ("MMC")
224obj-$(CONFIG_SOC_OMAP2420) += msdi.o
225
226# Specific board support
227obj-$(CONFIG_MACH_OMAP_GENERIC) += board-generic.o pdata-quirks.o
228obj-$(CONFIG_MACH_NOKIA_N8X0) += board-n8x0.o
229
230# Platform specific device init code
231
232omap-hsmmc-$(CONFIG_MMC_OMAP_HS) := hsmmc.o
233obj-y += $(omap-hsmmc-m) $(omap-hsmmc-y)
234
235obj-y += omap_phy_internal.o
236
237obj-$(CONFIG_MACH_OMAP2_TUSB6010) += usb-tusb6010.o
238
239arch/arm/mach-omap2/pm-asm-offsets.s: arch/arm/mach-omap2/pm-asm-offsets.c
240 $(call if_changed_dep,cc_s_c)
241
242include/generated/ti-pm-asm-offsets.h: arch/arm/mach-omap2/pm-asm-offsets.s FORCE
243 $(call filechk,offsets,__TI_PM_ASM_OFFSETS_H__)
244
245$(obj)/sleep33xx.o $(obj)/sleep43xx.o: include/generated/ti-pm-asm-offsets.h