blob: e6eec6f72fd3ed76b30af03bb4923fbacc62af7c [file] [log] [blame]
John Newlinb744f442016-06-21 10:48:09 -07001#
2# Makefile for the linux kernel.
3#
4
5ccflags-$(CONFIG_ARCH_MULTIPLATFORM) := -I$(srctree)/$(src)/include \
6 -I$(srctree)/arch/arm/plat-omap/include
7
8# Common support
9obj-y := id.o io.o control.o mux.o devices.o fb.o serial.o gpmc.o timer.o pm.o \
10 common.o gpio.o dma.o wd_timer.o display.o i2c.o hdq1w.o omap_hwmod.o \
11 omap_device.o sram.o drm.o
12
13omap-2-3-common = irq.o
14hwmod-common = omap_hwmod.o omap_hwmod_reset.o \
15 omap_hwmod_common_data.o
16clock-common = clock.o clock_common_data.o \
17 clkt_dpll.o clkt_clksel.o
18secure-common = omap-smc.o omap-secure.o
19
20obj-$(CONFIG_ARCH_OMAP2) += $(omap-2-3-common) $(hwmod-common)
21obj-$(CONFIG_ARCH_OMAP3) += $(omap-2-3-common) $(hwmod-common) $(secure-common)
22obj-$(CONFIG_ARCH_OMAP4) += $(hwmod-common) $(secure-common)
23obj-$(CONFIG_SOC_AM33XX) += irq.o $(hwmod-common)
24obj-$(CONFIG_SOC_OMAP5) += $(hwmod-common) $(secure-common)
25obj-$(CONFIG_SOC_AM43XX) += $(hwmod-common) $(secure-common)
26obj-$(CONFIG_SOC_DRA7XX) += $(hwmod-common) $(secure-common)
27
28ifneq ($(CONFIG_SND_OMAP_SOC_MCBSP),)
29obj-y += mcbsp.o
30endif
31
32obj-$(CONFIG_TWL4030_CORE) += omap_twl.o
33obj-$(CONFIG_SOC_HAS_OMAP2_SDRC) += sdrc.o
34
35# SMP support ONLY available for OMAP4
36
37smp-$(CONFIG_SMP) += omap-smp.o omap-headsmp.o
38smp-$(CONFIG_HOTPLUG_CPU) += omap-hotplug.o
39omap-4-5-common = omap4-common.o omap-wakeupgen.o
40obj-$(CONFIG_ARCH_OMAP4) += $(omap-4-5-common) $(smp-y) sleep44xx.o
41obj-$(CONFIG_SOC_OMAP5) += $(omap-4-5-common) $(smp-y) sleep44xx.o
42obj-$(CONFIG_SOC_AM43XX) += $(omap-4-5-common)
43obj-$(CONFIG_SOC_DRA7XX) += $(omap-4-5-common) $(smp-y) sleep44xx.o
44
45plus_sec := $(call as-instr,.arch_extension sec,+sec)
46AFLAGS_omap-headsmp.o :=-Wa,-march=armv7-a$(plus_sec)
47AFLAGS_omap-smc.o :=-Wa,-march=armv7-a$(plus_sec)
48AFLAGS_sleep44xx.o :=-Wa,-march=armv7-a$(plus_sec)
49
50# Functions loaded to SRAM
51obj-$(CONFIG_SOC_OMAP2420) += sram242x.o
52obj-$(CONFIG_SOC_OMAP2430) += sram243x.o
53obj-$(CONFIG_ARCH_OMAP3) += sram34xx.o
54
55AFLAGS_sram242x.o :=-Wa,-march=armv6
56AFLAGS_sram243x.o :=-Wa,-march=armv6
57AFLAGS_sram34xx.o :=-Wa,-march=armv7-a
58
59# Restart code (OMAP4/5 currently in omap4-common.c)
60obj-$(CONFIG_SOC_OMAP2420) += omap2-restart.o
61obj-$(CONFIG_SOC_OMAP2430) += omap2-restart.o
62obj-$(CONFIG_SOC_AM33XX) += am33xx-restart.o
63obj-$(CONFIG_ARCH_OMAP3) += omap3-restart.o
64obj-$(CONFIG_ARCH_OMAP4) += omap4-restart.o
65obj-$(CONFIG_SOC_OMAP5) += omap4-restart.o
66obj-$(CONFIG_SOC_DRA7XX) += omap4-restart.o
67
68# Pin multiplexing
69obj-$(CONFIG_ARCH_OMAP3) += mux34xx.o
70
71# SMS/SDRC
72obj-$(CONFIG_ARCH_OMAP2) += sdrc2xxx.o
73# obj-$(CONFIG_ARCH_OMAP3) += sdrc3xxx.o
74
75# OPP table initialization
76ifeq ($(CONFIG_PM_OPP),y)
77obj-y += opp.o
78obj-$(CONFIG_ARCH_OMAP3) += opp3xxx_data.o
79obj-$(CONFIG_ARCH_OMAP4) += opp4xxx_data.o
80endif
81
82# Power Management
83obj-$(CONFIG_OMAP_PM_NOOP) += omap-pm-noop.o
84
85ifeq ($(CONFIG_PM),y)
86obj-$(CONFIG_ARCH_OMAP2) += pm24xx.o
87obj-$(CONFIG_ARCH_OMAP2) += sleep24xx.o
88obj-$(CONFIG_ARCH_OMAP3) += pm34xx.o sleep34xx.o
89obj-$(CONFIG_ARCH_OMAP4) += pm44xx.o omap-mpuss-lowpower.o
90obj-$(CONFIG_SOC_OMAP5) += omap-mpuss-lowpower.o
91obj-$(CONFIG_SOC_DRA7XX) += omap-mpuss-lowpower.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)
99
100endif
101
102ifeq ($(CONFIG_CPU_IDLE),y)
103obj-$(CONFIG_ARCH_OMAP3) += cpuidle34xx.o
104obj-$(CONFIG_ARCH_OMAP4) += cpuidle44xx.o
105endif
106
107# PRCM
108obj-y += prm_common.o cm_common.o
109obj-$(CONFIG_ARCH_OMAP2) += prm2xxx_3xxx.o prm2xxx.o cm2xxx.o
110obj-$(CONFIG_ARCH_OMAP3) += prm2xxx_3xxx.o prm3xxx.o cm3xxx.o
111obj-$(CONFIG_ARCH_OMAP3) += vc3xxx_data.o vp3xxx_data.o
112obj-$(CONFIG_SOC_AM33XX) += prm33xx.o cm33xx.o
113omap-prcm-4-5-common = cminst44xx.o cm44xx.o prm44xx.o \
114 prcm_mpu44xx.o prminst44xx.o \
115 vc44xx_data.o vp44xx_data.o
116obj-$(CONFIG_ARCH_OMAP4) += $(omap-prcm-4-5-common)
117obj-$(CONFIG_SOC_OMAP5) += $(omap-prcm-4-5-common)
118obj-$(CONFIG_SOC_DRA7XX) += $(omap-prcm-4-5-common)
119obj-$(CONFIG_SOC_AM43XX) += $(omap-prcm-4-5-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_AM43XX) += $(clockdomain-common)
168obj-$(CONFIG_SOC_AM43XX) += clockdomains43xx_data.o
169obj-$(CONFIG_SOC_OMAP5) += $(clockdomain-common)
170obj-$(CONFIG_SOC_OMAP5) += clockdomains54xx_data.o
171obj-$(CONFIG_SOC_DRA7XX) += $(clockdomain-common)
172obj-$(CONFIG_SOC_DRA7XX) += clockdomains7xx_data.o
173
174# Clock framework
175obj-$(CONFIG_ARCH_OMAP2) += $(clock-common) clock2xxx.o
176obj-$(CONFIG_ARCH_OMAP2) += clkt2xxx_sys.o
177obj-$(CONFIG_ARCH_OMAP2) += clkt2xxx_dpllcore.o
178obj-$(CONFIG_ARCH_OMAP2) += clkt2xxx_virt_prcm_set.o
179obj-$(CONFIG_ARCH_OMAP2) += clkt2xxx_apll.o clkt2xxx_osc.o
180obj-$(CONFIG_ARCH_OMAP2) += clkt2xxx_dpll.o clkt_iclk.o
181obj-$(CONFIG_SOC_OMAP2420) += cclock2420_data.o
182obj-$(CONFIG_SOC_OMAP2430) += clock2430.o cclock2430_data.o
183obj-$(CONFIG_ARCH_OMAP3) += $(clock-common) clock3xxx.o
184obj-$(CONFIG_ARCH_OMAP3) += clock34xx.o clkt34xx_dpll3m2.o
185obj-$(CONFIG_ARCH_OMAP3) += clock3517.o clock36xx.o
186obj-$(CONFIG_ARCH_OMAP3) += dpll3xxx.o cclock3xxx_data.o
187obj-$(CONFIG_ARCH_OMAP3) += clkt_iclk.o
188obj-$(CONFIG_ARCH_OMAP4) += $(clock-common)
189obj-$(CONFIG_ARCH_OMAP4) += dpll3xxx.o dpll44xx.o
190obj-$(CONFIG_SOC_AM33XX) += $(clock-common) dpll3xxx.o
191obj-$(CONFIG_SOC_OMAP5) += $(clock-common)
192obj-$(CONFIG_SOC_OMAP5) += dpll3xxx.o dpll44xx.o
193obj-$(CONFIG_SOC_DRA7XX) += $(clock-common)
194obj-$(CONFIG_SOC_DRA7XX) += dpll3xxx.o dpll44xx.o
195obj-$(CONFIG_SOC_AM43XX) += $(clock-common) dpll3xxx.o
196
197# OMAP2 clock rate set data (old "OPP" data)
198obj-$(CONFIG_SOC_OMAP2420) += opp2420_data.o
199obj-$(CONFIG_SOC_OMAP2430) += opp2430_data.o
200
201# hwmod data
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_2xxx_3xxx_interconnect_data.o
206obj-$(CONFIG_SOC_OMAP2420) += omap_hwmod_2420_data.o
207obj-$(CONFIG_SOC_OMAP2430) += omap_hwmod_2xxx_ipblock_data.o
208obj-$(CONFIG_SOC_OMAP2430) += omap_hwmod_2xxx_3xxx_ipblock_data.o
209obj-$(CONFIG_SOC_OMAP2430) += omap_hwmod_2xxx_interconnect_data.o
210obj-$(CONFIG_SOC_OMAP2430) += omap_hwmod_2xxx_3xxx_interconnect_data.o
211obj-$(CONFIG_SOC_OMAP2430) += omap_hwmod_2430_data.o
212obj-$(CONFIG_ARCH_OMAP3) += omap_hwmod_2xxx_3xxx_ipblock_data.o
213obj-$(CONFIG_ARCH_OMAP3) += omap_hwmod_2xxx_3xxx_interconnect_data.o
214obj-$(CONFIG_ARCH_OMAP3) += omap_hwmod_3xxx_data.o
215obj-$(CONFIG_SOC_AM33XX) += omap_hwmod_33xx_data.o
216obj-$(CONFIG_SOC_AM33XX) += omap_hwmod_33xx_43xx_interconnect_data.o
217obj-$(CONFIG_SOC_AM33XX) += omap_hwmod_33xx_43xx_ipblock_data.o
218obj-$(CONFIG_SOC_AM43XX) += omap_hwmod_43xx_data.o
219obj-$(CONFIG_SOC_AM43XX) += omap_hwmod_33xx_43xx_interconnect_data.o
220obj-$(CONFIG_SOC_AM43XX) += omap_hwmod_33xx_43xx_ipblock_data.o
221obj-$(CONFIG_ARCH_OMAP4) += omap_hwmod_44xx_data.o
222obj-$(CONFIG_SOC_OMAP5) += omap_hwmod_54xx_data.o
223obj-$(CONFIG_SOC_DRA7XX) += omap_hwmod_7xx_data.o
224
225# EMU peripherals
226obj-$(CONFIG_OMAP3_EMU) += emu.o
227obj-$(CONFIG_HW_PERF_EVENTS) += pmu.o
228
229iommu-$(CONFIG_OMAP_IOMMU) := omap-iommu.o
230obj-y += $(iommu-m) $(iommu-y)
231
232ifneq ($(CONFIG_TIDSPBRIDGE),)
233obj-y += dsp.o
234endif
235
236# OMAP2420 MSDI controller integration support ("MMC")
237obj-$(CONFIG_SOC_OMAP2420) += msdi.o
238
239# Specific board support
240obj-$(CONFIG_MACH_OMAP_GENERIC) += board-generic.o pdata-quirks.o
241obj-$(CONFIG_MACH_OMAP3_BEAGLE) += board-omap3beagle.o
242obj-$(CONFIG_MACH_DEVKIT8000) += board-devkit8000.o
243obj-$(CONFIG_MACH_OMAP_LDP) += board-ldp.o
244obj-$(CONFIG_MACH_OMAP3530_LV_SOM) += board-omap3logic.o
245obj-$(CONFIG_MACH_OMAP3_TORPEDO) += board-omap3logic.o
246obj-$(CONFIG_MACH_OVERO) += board-overo.o
247obj-$(CONFIG_MACH_OMAP3_PANDORA) += board-omap3pandora.o
248obj-$(CONFIG_MACH_OMAP_3430SDP) += board-3430sdp.o
249obj-$(CONFIG_MACH_NOKIA_N8X0) += board-n8x0.o
250obj-$(CONFIG_MACH_NOKIA_RX51) += board-rx51.o sdram-nokia.o
251obj-$(CONFIG_MACH_NOKIA_RX51) += board-rx51-peripherals.o
252obj-$(CONFIG_MACH_NOKIA_RX51) += board-rx51-video.o
253obj-$(CONFIG_MACH_CM_T35) += board-cm-t35.o
254obj-$(CONFIG_MACH_CM_T3517) += board-cm-t3517.o
255obj-$(CONFIG_MACH_TOUCHBOOK) += board-omap3touchbook.o
256
257obj-$(CONFIG_MACH_OMAP3517EVM) += board-am3517evm.o
258
259obj-$(CONFIG_MACH_CRANEBOARD) += board-am3517crane.o
260
261obj-$(CONFIG_MACH_SBC3530) += board-omap3stalker.o
262obj-$(CONFIG_MACH_TI8168EVM) += board-ti8168evm.o
263obj-$(CONFIG_MACH_TI8148EVM) += board-ti8168evm.o
264
265# Platform specific device init code
266
267omap-flash-$(CONFIG_MTD_NAND_OMAP2) := board-flash.o
268omap-flash-$(CONFIG_MTD_ONENAND_OMAP2) := board-flash.o
269obj-y += $(omap-flash-y) $(omap-flash-m)
270
271omap-hsmmc-$(CONFIG_MMC_OMAP_HS) := hsmmc.o
272obj-y += $(omap-hsmmc-m) $(omap-hsmmc-y)
273
274obj-y += usb-musb.o
275obj-y += omap_phy_internal.o
276
277obj-$(CONFIG_MACH_OMAP2_TUSB6010) += usb-tusb6010.o
278obj-y += usb-host.o
279
280onenand-$(CONFIG_MTD_ONENAND_OMAP2) := gpmc-onenand.o
281obj-y += $(onenand-m) $(onenand-y)
282
283nand-$(CONFIG_MTD_NAND_OMAP2) := gpmc-nand.o
284obj-y += $(nand-m) $(nand-y)
285
286smc91x-$(CONFIG_SMC91X) := gpmc-smc91x.o
287obj-y += $(smc91x-m) $(smc91x-y)
288
289smsc911x-$(CONFIG_SMSC911X) := gpmc-smsc911x.o
290obj-y += $(smsc911x-m) $(smsc911x-y)
291ifneq ($(CONFIG_HWSPINLOCK_OMAP),)
292obj-y += hwspinlock.o
293endif
294
295emac-$(CONFIG_TI_DAVINCI_EMAC) := am35xx-emac.o
296obj-y += $(emac-m) $(emac-y)
297
298obj-y += common-board-devices.o twl-common.o dss-common.o