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