xref: /openbmc/linux/arch/arm/mach-omap2/Makefile (revision cd5d5810)
1#
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
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) += prm44xx.o $(hwmod-common) $(secure-common)
23obj-$(CONFIG_SOC_AM33XX) += irq.o $(hwmod-common)
24obj-$(CONFIG_SOC_OMAP5)	 += prm44xx.o $(hwmod-common) $(secure-common)
25obj-$(CONFIG_SOC_AM43XX) += $(hwmod-common) $(secure-common)
26obj-$(CONFIG_SOC_DRA7XX) += prm44xx.o $(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)
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_SOC_OMAP2420)		+= mux2420.o
70obj-$(CONFIG_SOC_OMAP2430)		+= mux2430.o
71obj-$(CONFIG_ARCH_OMAP3)		+= mux34xx.o
72
73# SMS/SDRC
74obj-$(CONFIG_ARCH_OMAP2)		+= sdrc2xxx.o
75# obj-$(CONFIG_ARCH_OMAP3)		+= sdrc3xxx.o
76
77# OPP table initialization
78ifeq ($(CONFIG_PM_OPP),y)
79obj-y					+= opp.o
80obj-$(CONFIG_ARCH_OMAP3)		+= opp3xxx_data.o
81obj-$(CONFIG_ARCH_OMAP4)		+= opp4xxx_data.o
82endif
83
84# Power Management
85obj-$(CONFIG_OMAP_PM_NOOP)		+= omap-pm-noop.o
86
87ifeq ($(CONFIG_PM),y)
88obj-$(CONFIG_ARCH_OMAP2)		+= pm24xx.o
89obj-$(CONFIG_ARCH_OMAP2)		+= sleep24xx.o
90obj-$(CONFIG_ARCH_OMAP3)		+= pm34xx.o sleep34xx.o
91obj-$(CONFIG_ARCH_OMAP4)		+= pm44xx.o omap-mpuss-lowpower.o
92obj-$(CONFIG_SOC_OMAP5)			+= omap-mpuss-lowpower.o
93obj-$(CONFIG_SOC_DRA7XX)		+= omap-mpuss-lowpower.o
94obj-$(CONFIG_PM_DEBUG)			+= pm-debug.o
95
96obj-$(CONFIG_POWER_AVS_OMAP)		+= sr_device.o
97obj-$(CONFIG_POWER_AVS_OMAP_CLASS3)    += smartreflex-class3.o
98
99AFLAGS_sleep24xx.o			:=-Wa,-march=armv6
100AFLAGS_sleep34xx.o			:=-Wa,-march=armv7-a$(plus_sec)
101
102endif
103
104ifeq ($(CONFIG_CPU_IDLE),y)
105obj-$(CONFIG_ARCH_OMAP3)                += cpuidle34xx.o
106obj-$(CONFIG_ARCH_OMAP4)                += cpuidle44xx.o
107endif
108
109# PRCM
110obj-y					+= prm_common.o cm_common.o
111obj-$(CONFIG_ARCH_OMAP2)		+= prm2xxx_3xxx.o prm2xxx.o cm2xxx.o
112obj-$(CONFIG_ARCH_OMAP3)		+= prm2xxx_3xxx.o prm3xxx.o cm3xxx.o
113obj-$(CONFIG_ARCH_OMAP3)		+= vc3xxx_data.o vp3xxx_data.o
114obj-$(CONFIG_SOC_AM33XX)		+= prm33xx.o cm33xx.o
115obj-$(CONFIG_SOC_AM43XX)		+= prm33xx.o cm33xx.o
116omap-prcm-4-5-common			=  cminst44xx.o cm44xx.o prm44xx.o \
117					   prcm_mpu44xx.o prminst44xx.o \
118					   vc44xx_data.o vp44xx_data.o
119obj-$(CONFIG_ARCH_OMAP4)		+= $(omap-prcm-4-5-common)
120obj-$(CONFIG_SOC_OMAP5)			+= $(omap-prcm-4-5-common)
121obj-$(CONFIG_SOC_DRA7XX)		+= $(omap-prcm-4-5-common)
122
123# OMAP voltage domains
124voltagedomain-common			:= voltage.o vc.o vp.o
125obj-$(CONFIG_ARCH_OMAP2)		+= $(voltagedomain-common)
126obj-$(CONFIG_ARCH_OMAP2)		+= voltagedomains2xxx_data.o
127obj-$(CONFIG_ARCH_OMAP3)		+= $(voltagedomain-common)
128obj-$(CONFIG_ARCH_OMAP3)		+= voltagedomains3xxx_data.o
129obj-$(CONFIG_ARCH_OMAP4)		+= $(voltagedomain-common)
130obj-$(CONFIG_ARCH_OMAP4)		+= voltagedomains44xx_data.o
131obj-$(CONFIG_SOC_AM33XX)		+= $(voltagedomain-common)
132obj-$(CONFIG_SOC_AM43XX)		+= $(voltagedomain-common)
133obj-$(CONFIG_SOC_OMAP5)			+= $(voltagedomain-common)
134obj-$(CONFIG_SOC_OMAP5)                += voltagedomains54xx_data.o
135
136# OMAP powerdomain framework
137powerdomain-common			+= powerdomain.o powerdomain-common.o
138obj-$(CONFIG_ARCH_OMAP2)		+= $(powerdomain-common)
139obj-$(CONFIG_ARCH_OMAP2)		+= powerdomains2xxx_data.o
140obj-$(CONFIG_ARCH_OMAP2)		+= powerdomains2xxx_3xxx_data.o
141obj-$(CONFIG_ARCH_OMAP3)		+= $(powerdomain-common)
142obj-$(CONFIG_ARCH_OMAP3)		+= powerdomains3xxx_data.o
143obj-$(CONFIG_ARCH_OMAP3)		+= powerdomains2xxx_3xxx_data.o
144obj-$(CONFIG_ARCH_OMAP4)		+= $(powerdomain-common)
145obj-$(CONFIG_ARCH_OMAP4)		+= powerdomains44xx_data.o
146obj-$(CONFIG_SOC_AM33XX)		+= $(powerdomain-common)
147obj-$(CONFIG_SOC_AM33XX)		+= powerdomains33xx_data.o
148obj-$(CONFIG_SOC_AM43XX)		+= $(powerdomain-common)
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_OMAP5)			+= $(clockdomain-common)
169obj-$(CONFIG_SOC_OMAP5)			+= clockdomains54xx_data.o
170obj-$(CONFIG_SOC_DRA7XX)		+= $(clockdomain-common)
171obj-$(CONFIG_SOC_DRA7XX)		+= clockdomains7xx_data.o
172
173# Clock framework
174obj-$(CONFIG_ARCH_OMAP2)		+= $(clock-common) clock2xxx.o
175obj-$(CONFIG_ARCH_OMAP2)		+= clkt2xxx_sys.o
176obj-$(CONFIG_ARCH_OMAP2)		+= clkt2xxx_dpllcore.o
177obj-$(CONFIG_ARCH_OMAP2)		+= clkt2xxx_virt_prcm_set.o
178obj-$(CONFIG_ARCH_OMAP2)		+= clkt2xxx_apll.o clkt2xxx_osc.o
179obj-$(CONFIG_ARCH_OMAP2)		+= clkt2xxx_dpll.o clkt_iclk.o
180obj-$(CONFIG_SOC_OMAP2420)		+= cclock2420_data.o
181obj-$(CONFIG_SOC_OMAP2430)		+= clock2430.o cclock2430_data.o
182obj-$(CONFIG_ARCH_OMAP3)		+= $(clock-common) clock3xxx.o
183obj-$(CONFIG_ARCH_OMAP3)		+= clock34xx.o clkt34xx_dpll3m2.o
184obj-$(CONFIG_ARCH_OMAP3)		+= clock3517.o clock36xx.o
185obj-$(CONFIG_ARCH_OMAP3)		+= dpll3xxx.o cclock3xxx_data.o
186obj-$(CONFIG_ARCH_OMAP3)		+= clkt_iclk.o
187obj-$(CONFIG_ARCH_OMAP4)		+= $(clock-common) cclock44xx_data.o
188obj-$(CONFIG_ARCH_OMAP4)		+= dpll3xxx.o dpll44xx.o
189obj-$(CONFIG_SOC_AM33XX)		+= $(clock-common) dpll3xxx.o
190obj-$(CONFIG_SOC_AM33XX)		+= cclock33xx_data.o
191obj-$(CONFIG_SOC_OMAP5)			+= $(clock-common)
192obj-$(CONFIG_SOC_OMAP5)			+= dpll3xxx.o dpll44xx.o
193
194# OMAP2 clock rate set data (old "OPP" data)
195obj-$(CONFIG_SOC_OMAP2420)		+= opp2420_data.o
196obj-$(CONFIG_SOC_OMAP2430)		+= opp2430_data.o
197
198# hwmod data
199obj-$(CONFIG_SOC_OMAP2420)		+= omap_hwmod_2xxx_ipblock_data.o
200obj-$(CONFIG_SOC_OMAP2420)		+= omap_hwmod_2xxx_3xxx_ipblock_data.o
201obj-$(CONFIG_SOC_OMAP2420)		+= omap_hwmod_2xxx_interconnect_data.o
202obj-$(CONFIG_SOC_OMAP2420)		+= omap_hwmod_2xxx_3xxx_interconnect_data.o
203obj-$(CONFIG_SOC_OMAP2420)		+= omap_hwmod_2420_data.o
204obj-$(CONFIG_SOC_OMAP2430)		+= omap_hwmod_2xxx_ipblock_data.o
205obj-$(CONFIG_SOC_OMAP2430)		+= omap_hwmod_2xxx_3xxx_ipblock_data.o
206obj-$(CONFIG_SOC_OMAP2430)		+= omap_hwmod_2xxx_interconnect_data.o
207obj-$(CONFIG_SOC_OMAP2430)		+= omap_hwmod_2xxx_3xxx_interconnect_data.o
208obj-$(CONFIG_SOC_OMAP2430)		+= omap_hwmod_2430_data.o
209obj-$(CONFIG_ARCH_OMAP3)		+= omap_hwmod_2xxx_3xxx_ipblock_data.o
210obj-$(CONFIG_ARCH_OMAP3)		+= omap_hwmod_2xxx_3xxx_interconnect_data.o
211obj-$(CONFIG_ARCH_OMAP3)		+= omap_hwmod_3xxx_data.o
212obj-$(CONFIG_SOC_AM33XX)		+= omap_hwmod_33xx_data.o
213obj-$(CONFIG_ARCH_OMAP4)		+= omap_hwmod_44xx_data.o
214obj-$(CONFIG_SOC_OMAP5)			+= omap_hwmod_54xx_data.o
215obj-$(CONFIG_SOC_DRA7XX)		+= omap_hwmod_7xx_data.o
216
217# EMU peripherals
218obj-$(CONFIG_OMAP3_EMU)			+= emu.o
219obj-$(CONFIG_HW_PERF_EVENTS)		+= pmu.o
220
221iommu-$(CONFIG_OMAP_IOMMU)		:= omap-iommu.o
222obj-y					+= $(iommu-m) $(iommu-y)
223
224ifneq ($(CONFIG_TIDSPBRIDGE),)
225obj-y					+= dsp.o
226endif
227
228# OMAP2420 MSDI controller integration support ("MMC")
229obj-$(CONFIG_SOC_OMAP2420)		+= msdi.o
230
231ifneq ($(CONFIG_DRM_OMAP),)
232obj-y					+= drm.o
233endif
234
235# Specific board support
236obj-$(CONFIG_MACH_OMAP_GENERIC)		+= board-generic.o
237obj-$(CONFIG_MACH_OMAP_H4)		+= board-h4.o
238obj-$(CONFIG_MACH_OMAP_2430SDP)		+= board-2430sdp.o
239obj-$(CONFIG_MACH_OMAP3_BEAGLE)		+= board-omap3beagle.o
240obj-$(CONFIG_MACH_DEVKIT8000)     	+= board-devkit8000.o
241obj-$(CONFIG_MACH_OMAP_LDP)		+= board-ldp.o
242obj-$(CONFIG_MACH_OMAP3530_LV_SOM)      += board-omap3logic.o
243obj-$(CONFIG_MACH_OMAP3_TORPEDO)        += board-omap3logic.o
244obj-$(CONFIG_MACH_OVERO)		+= board-overo.o
245obj-$(CONFIG_MACH_OMAP3EVM)		+= board-omap3evm.o
246obj-$(CONFIG_MACH_OMAP3_PANDORA)	+= board-omap3pandora.o
247obj-$(CONFIG_MACH_OMAP_3430SDP)		+= board-3430sdp.o
248obj-$(CONFIG_MACH_NOKIA_N8X0)		+= board-n8x0.o
249obj-$(CONFIG_MACH_NOKIA_RM680)		+= board-rm680.o sdram-nokia.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_OMAP_ZOOM2)		+= board-zoom.o board-zoom-peripherals.o
254obj-$(CONFIG_MACH_OMAP_ZOOM2)		+= board-zoom-display.o
255obj-$(CONFIG_MACH_OMAP_ZOOM2)		+= board-zoom-debugboard.o
256obj-$(CONFIG_MACH_OMAP_ZOOM3)		+= board-zoom.o board-zoom-peripherals.o
257obj-$(CONFIG_MACH_OMAP_ZOOM3)		+= board-zoom-display.o
258obj-$(CONFIG_MACH_OMAP_ZOOM3)		+= board-zoom-debugboard.o
259obj-$(CONFIG_MACH_OMAP_3630SDP)		+= board-3630sdp.o
260obj-$(CONFIG_MACH_OMAP_3630SDP)		+= board-zoom-peripherals.o
261obj-$(CONFIG_MACH_OMAP_3630SDP)		+= board-zoom-display.o
262obj-$(CONFIG_MACH_CM_T35)		+= board-cm-t35.o
263obj-$(CONFIG_MACH_CM_T3517)		+= board-cm-t3517.o
264obj-$(CONFIG_MACH_IGEP0020)		+= board-igep0020.o
265obj-$(CONFIG_MACH_TOUCHBOOK)		+= board-omap3touchbook.o
266
267obj-$(CONFIG_MACH_OMAP3517EVM)		+= board-am3517evm.o
268
269obj-$(CONFIG_MACH_CRANEBOARD)		+= board-am3517crane.o
270
271obj-$(CONFIG_MACH_SBC3530)		+= board-omap3stalker.o
272obj-$(CONFIG_MACH_TI8168EVM)		+= board-ti8168evm.o
273obj-$(CONFIG_MACH_TI8148EVM)		+= board-ti8168evm.o
274
275# Platform specific device init code
276
277omap-flash-$(CONFIG_MTD_NAND_OMAP2)	:= board-flash.o
278omap-flash-$(CONFIG_MTD_ONENAND_OMAP2)	:= board-flash.o
279obj-y					+= $(omap-flash-y) $(omap-flash-m)
280
281omap-hsmmc-$(CONFIG_MMC_OMAP_HS)	:= hsmmc.o
282obj-y					+= $(omap-hsmmc-m) $(omap-hsmmc-y)
283
284obj-y					+= usb-musb.o
285obj-y					+= omap_phy_internal.o
286
287obj-$(CONFIG_MACH_OMAP2_TUSB6010)	+= usb-tusb6010.o
288obj-y					+= usb-host.o
289
290onenand-$(CONFIG_MTD_ONENAND_OMAP2)	:= gpmc-onenand.o
291obj-y					+= $(onenand-m) $(onenand-y)
292
293nand-$(CONFIG_MTD_NAND_OMAP2)		:= gpmc-nand.o
294obj-y					+= $(nand-m) $(nand-y)
295
296smc91x-$(CONFIG_SMC91X)			:= gpmc-smc91x.o
297obj-y					+= $(smc91x-m) $(smc91x-y)
298
299smsc911x-$(CONFIG_SMSC911X)		:= gpmc-smsc911x.o
300obj-y					+= $(smsc911x-m) $(smsc911x-y)
301ifneq ($(CONFIG_HWSPINLOCK_OMAP),)
302obj-y					+= hwspinlock.o
303endif
304
305emac-$(CONFIG_TI_DAVINCI_EMAC)		:= am35xx-emac.o
306obj-y					+= $(emac-m) $(emac-y)
307
308obj-y					+= common-board-devices.o twl-common.o dss-common.o
309