blob: 49f92bc1c311fd41078da192afbb84f2878f4ee7 [file] [log] [blame]
yuezonghe824eb0c2024-06-27 02:32:26 -07001#
2# Makefile for the linux kernel.
3#
4
5# Common support
6obj-y := id.o io.o control.o mux.o devices.o serial.o gpmc.o timer.o pm.o \
7 common.o gpio.o dma.o wd_timer.o display.o i2c.o
8
9omap-2-3-common = irq.o sdrc.o
10hwmod-common = omap_hwmod.o \
11 omap_hwmod_common_data.o
12clock-common = clock.o clock_common_data.o \
13 clkt_dpll.o clkt_clksel.o
14secure-common = omap-smc.o omap-secure.o
15
16obj-$(CONFIG_ARCH_OMAP2) += $(omap-2-3-common) $(hwmod-common)
17obj-$(CONFIG_ARCH_OMAP3) += $(omap-2-3-common) $(hwmod-common) $(secure-common)
18obj-$(CONFIG_ARCH_OMAP4) += prm44xx.o $(hwmod-common) $(secure-common)
19
20ifneq ($(CONFIG_SND_OMAP_SOC_MCBSP),)
21obj-y += mcbsp.o
22endif
23
24obj-$(CONFIG_TWL4030_CORE) += omap_twl.o
25
26# SMP support ONLY available for OMAP4
27obj-$(CONFIG_SMP) += omap-smp.o omap-headsmp.o
28obj-$(CONFIG_HOTPLUG_CPU) += omap-hotplug.o
29obj-$(CONFIG_ARCH_OMAP4) += omap4-common.o omap-wakeupgen.o \
30 sleep44xx.o
31
32plus_sec := $(call as-instr,.arch_extension sec,+sec)
33AFLAGS_omap-headsmp.o :=-Wa,-march=armv7-a$(plus_sec)
34AFLAGS_omap-smc.o :=-Wa,-march=armv7-a$(plus_sec)
35AFLAGS_sleep44xx.o :=-Wa,-march=armv7-a$(plus_sec)
36
37# Functions loaded to SRAM
38obj-$(CONFIG_SOC_OMAP2420) += sram242x.o
39obj-$(CONFIG_SOC_OMAP2430) += sram243x.o
40obj-$(CONFIG_ARCH_OMAP3) += sram34xx.o
41
42AFLAGS_sram242x.o :=-Wa,-march=armv6
43AFLAGS_sram243x.o :=-Wa,-march=armv6
44AFLAGS_sram34xx.o :=-Wa,-march=armv7-a
45
46# Pin multiplexing
47obj-$(CONFIG_SOC_OMAP2420) += mux2420.o
48obj-$(CONFIG_SOC_OMAP2430) += mux2430.o
49obj-$(CONFIG_ARCH_OMAP3) += mux34xx.o
50obj-$(CONFIG_ARCH_OMAP4) += mux44xx.o
51
52# SMS/SDRC
53obj-$(CONFIG_ARCH_OMAP2) += sdrc2xxx.o
54# obj-$(CONFIG_ARCH_OMAP3) += sdrc3xxx.o
55
56# OPP table initialization
57ifeq ($(CONFIG_PM_OPP),y)
58obj-y += opp.o
59obj-$(CONFIG_ARCH_OMAP3) += opp3xxx_data.o
60obj-$(CONFIG_ARCH_OMAP4) += opp4xxx_data.o
61endif
62
63# Power Management
64ifeq ($(CONFIG_PM),y)
65obj-$(CONFIG_ARCH_OMAP2) += pm24xx.o
66obj-$(CONFIG_ARCH_OMAP2) += sleep24xx.o
67obj-$(CONFIG_ARCH_OMAP3) += pm34xx.o sleep34xx.o \
68 cpuidle34xx.o
69obj-$(CONFIG_ARCH_OMAP4) += pm44xx.o omap-mpuss-lowpower.o \
70 cpuidle44xx.o
71obj-$(CONFIG_PM_DEBUG) += pm-debug.o
72obj-$(CONFIG_OMAP_SMARTREFLEX) += sr_device.o smartreflex.o
73obj-$(CONFIG_OMAP_SMARTREFLEX_CLASS3) += smartreflex-class3.o
74
75AFLAGS_sleep24xx.o :=-Wa,-march=armv6
76AFLAGS_sleep34xx.o :=-Wa,-march=armv7-a$(plus_sec)
77
78ifeq ($(CONFIG_PM_VERBOSE),y)
79CFLAGS_pm_bus.o += -DDEBUG
80endif
81
82endif
83
84# PRCM
85obj-y += prm_common.o
86obj-$(CONFIG_ARCH_OMAP2) += prcm.o cm2xxx_3xxx.o prm2xxx_3xxx.o
87obj-$(CONFIG_ARCH_OMAP3) += prcm.o cm2xxx_3xxx.o prm2xxx_3xxx.o \
88 vc3xxx_data.o vp3xxx_data.o
89# XXX The presence of cm2xxx_3xxx.o on the line below is temporary and
90# will be removed once the OMAP4 part of the codebase is converted to
91# use OMAP4-specific PRCM functions.
92obj-$(CONFIG_ARCH_OMAP4) += prcm.o cm2xxx_3xxx.o cminst44xx.o \
93 cm44xx.o prcm_mpu44xx.o \
94 prminst44xx.o vc44xx_data.o \
95 vp44xx_data.o prm44xx.o
96
97# OMAP voltage domains
98voltagedomain-common := voltage.o vc.o vp.o
99obj-$(CONFIG_ARCH_OMAP2) += $(voltagedomain-common) \
100 voltagedomains2xxx_data.o
101obj-$(CONFIG_ARCH_OMAP3) += $(voltagedomain-common) \
102 voltagedomains3xxx_data.o
103obj-$(CONFIG_ARCH_OMAP4) += $(voltagedomain-common) \
104 voltagedomains44xx_data.o
105
106# OMAP powerdomain framework
107powerdomain-common += powerdomain.o powerdomain-common.o
108obj-$(CONFIG_ARCH_OMAP2) += $(powerdomain-common) \
109 powerdomain2xxx_3xxx.o \
110 powerdomains2xxx_data.o \
111 powerdomains2xxx_3xxx_data.o
112obj-$(CONFIG_ARCH_OMAP3) += $(powerdomain-common) \
113 powerdomain2xxx_3xxx.o \
114 powerdomains3xxx_data.o \
115 powerdomains2xxx_3xxx_data.o
116obj-$(CONFIG_ARCH_OMAP4) += $(powerdomain-common) \
117 powerdomain44xx.o \
118 powerdomains44xx_data.o
119
120# PRCM clockdomain control
121obj-$(CONFIG_ARCH_OMAP2) += clockdomain.o \
122 clockdomain2xxx_3xxx.o \
123 clockdomains2xxx_3xxx_data.o
124obj-$(CONFIG_SOC_OMAP2420) += clockdomains2420_data.o
125obj-$(CONFIG_SOC_OMAP2430) += clockdomains2430_data.o
126obj-$(CONFIG_ARCH_OMAP3) += clockdomain.o \
127 clockdomain2xxx_3xxx.o \
128 clockdomains2xxx_3xxx_data.o \
129 clockdomains3xxx_data.o
130obj-$(CONFIG_ARCH_OMAP4) += clockdomain.o \
131 clockdomain44xx.o \
132 clockdomains44xx_data.o
133
134# Clock framework
135obj-$(CONFIG_ARCH_OMAP2) += $(clock-common) clock2xxx.o \
136 clkt2xxx_sys.o \
137 clkt2xxx_dpllcore.o \
138 clkt2xxx_virt_prcm_set.o \
139 clkt2xxx_apll.o clkt2xxx_osc.o \
140 clkt2xxx_dpll.o clkt_iclk.o
141obj-$(CONFIG_SOC_OMAP2420) += clock2420_data.o
142obj-$(CONFIG_SOC_OMAP2430) += clock2430.o clock2430_data.o
143obj-$(CONFIG_ARCH_OMAP3) += $(clock-common) clock3xxx.o \
144 clock34xx.o clkt34xx_dpll3m2.o \
145 clock3517.o clock36xx.o \
146 dpll3xxx.o clock3xxx_data.o \
147 clkt_iclk.o
148obj-$(CONFIG_ARCH_OMAP4) += $(clock-common) clock44xx_data.o \
149 dpll3xxx.o dpll44xx.o
150
151# OMAP2 clock rate set data (old "OPP" data)
152obj-$(CONFIG_SOC_OMAP2420) += opp2420_data.o
153obj-$(CONFIG_SOC_OMAP2430) += opp2430_data.o
154
155# hwmod data
156obj-$(CONFIG_SOC_OMAP2420) += omap_hwmod_2xxx_ipblock_data.o \
157 omap_hwmod_2xxx_3xxx_ipblock_data.o \
158 omap_hwmod_2xxx_interconnect_data.o \
159 omap_hwmod_2xxx_3xxx_interconnect_data.o \
160 omap_hwmod_2420_data.o
161obj-$(CONFIG_SOC_OMAP2430) += omap_hwmod_2xxx_ipblock_data.o \
162 omap_hwmod_2xxx_3xxx_ipblock_data.o \
163 omap_hwmod_2xxx_interconnect_data.o \
164 omap_hwmod_2xxx_3xxx_interconnect_data.o \
165 omap_hwmod_2430_data.o
166obj-$(CONFIG_ARCH_OMAP3) += omap_hwmod_2xxx_3xxx_ipblock_data.o \
167 omap_hwmod_2xxx_3xxx_interconnect_data.o \
168 omap_hwmod_3xxx_data.o
169obj-$(CONFIG_ARCH_OMAP4) += omap_hwmod_44xx_data.o
170
171# EMU peripherals
172obj-$(CONFIG_OMAP3_EMU) += emu.o
173
174# L3 interconnect
175obj-$(CONFIG_ARCH_OMAP3) += omap_l3_smx.o
176obj-$(CONFIG_ARCH_OMAP4) += omap_l3_noc.o
177
178obj-$(CONFIG_OMAP_MBOX_FWK) += mailbox_mach.o
179mailbox_mach-objs := mailbox.o
180
181obj-$(CONFIG_OMAP_IOMMU) += iommu2.o
182
183iommu-$(CONFIG_OMAP_IOMMU) := omap-iommu.o
184obj-y += $(iommu-m) $(iommu-y)
185
186ifneq ($(CONFIG_TIDSPBRIDGE),)
187obj-y += dsp.o
188endif
189
190# Specific board support
191obj-$(CONFIG_MACH_OMAP_GENERIC) += board-generic.o
192obj-$(CONFIG_MACH_OMAP_H4) += board-h4.o
193obj-$(CONFIG_MACH_OMAP_2430SDP) += board-2430sdp.o
194obj-$(CONFIG_MACH_OMAP_APOLLON) += board-apollon.o
195obj-$(CONFIG_MACH_OMAP3_BEAGLE) += board-omap3beagle.o
196obj-$(CONFIG_MACH_DEVKIT8000) += board-devkit8000.o
197obj-$(CONFIG_MACH_OMAP_LDP) += board-ldp.o
198obj-$(CONFIG_MACH_OMAP3530_LV_SOM) += board-omap3logic.o
199obj-$(CONFIG_MACH_OMAP3_TORPEDO) += board-omap3logic.o
200obj-$(CONFIG_MACH_ENCORE) += board-omap3encore.o
201obj-$(CONFIG_MACH_OVERO) += board-overo.o
202obj-$(CONFIG_MACH_OMAP3EVM) += board-omap3evm.o
203obj-$(CONFIG_MACH_OMAP3_PANDORA) += board-omap3pandora.o
204obj-$(CONFIG_MACH_OMAP_3430SDP) += board-3430sdp.o
205obj-$(CONFIG_MACH_NOKIA_N8X0) += board-n8x0.o
206obj-$(CONFIG_MACH_NOKIA_RM680) += board-rm680.o \
207 sdram-nokia.o
208obj-$(CONFIG_MACH_NOKIA_RX51) += board-rx51.o \
209 sdram-nokia.o \
210 board-rx51-peripherals.o \
211 board-rx51-video.o
212obj-$(CONFIG_MACH_OMAP_ZOOM2) += board-zoom.o \
213 board-zoom-peripherals.o \
214 board-zoom-display.o \
215 board-zoom-debugboard.o
216obj-$(CONFIG_MACH_OMAP_ZOOM3) += board-zoom.o \
217 board-zoom-peripherals.o \
218 board-zoom-display.o \
219 board-zoom-debugboard.o
220obj-$(CONFIG_MACH_OMAP_3630SDP) += board-3630sdp.o \
221 board-zoom-peripherals.o \
222 board-zoom-display.o
223obj-$(CONFIG_MACH_CM_T35) += board-cm-t35.o
224obj-$(CONFIG_MACH_CM_T3517) += board-cm-t3517.o
225obj-$(CONFIG_MACH_IGEP0020) += board-igep0020.o
226obj-$(CONFIG_MACH_OMAP3_TOUCHBOOK) += board-omap3touchbook.o
227obj-$(CONFIG_MACH_OMAP_4430SDP) += board-4430sdp.o
228obj-$(CONFIG_MACH_OMAP4_PANDA) += board-omap4panda.o
229
230obj-$(CONFIG_MACH_PCM049) += board-omap4pcm049.o
231
232obj-$(CONFIG_MACH_OMAP3517EVM) += board-am3517evm.o
233
234obj-$(CONFIG_MACH_CRANEBOARD) += board-am3517crane.o
235
236obj-$(CONFIG_MACH_SBC3530) += board-omap3stalker.o
237obj-$(CONFIG_MACH_TI8168EVM) += board-ti8168evm.o
238obj-$(CONFIG_MACH_TI8148EVM) += board-ti8168evm.o
239
240# Platform specific device init code
241
242omap-flash-$(CONFIG_MTD_NAND_OMAP2) := board-flash.o
243omap-flash-$(CONFIG_MTD_ONENAND_OMAP2) := board-flash.o
244obj-y += $(omap-flash-y) $(omap-flash-m)
245
246omap-hsmmc-$(CONFIG_MMC_OMAP_HS) := hsmmc.o
247obj-y += $(omap-hsmmc-m) $(omap-hsmmc-y)
248
249
250usbfs-$(CONFIG_ARCH_OMAP_OTG) := usb-fs.o
251obj-y += $(usbfs-m) $(usbfs-y)
252obj-y += usb-musb.o
253obj-y += omap_phy_internal.o
254
255obj-$(CONFIG_MACH_OMAP2_TUSB6010) += usb-tusb6010.o
256obj-y += usb-host.o
257
258onenand-$(CONFIG_MTD_ONENAND_OMAP2) := gpmc-onenand.o
259obj-y += $(onenand-m) $(onenand-y)
260
261nand-$(CONFIG_MTD_NAND_OMAP2) := gpmc-nand.o
262obj-y += $(nand-m) $(nand-y)
263
264smc91x-$(CONFIG_SMC91X) := gpmc-smc91x.o
265obj-y += $(smc91x-m) $(smc91x-y)
266
267smsc911x-$(CONFIG_SMSC911X) := gpmc-smsc911x.o
268obj-y += $(smsc911x-m) $(smsc911x-y)
269ifneq ($(CONFIG_HWSPINLOCK_OMAP),)
270obj-y += hwspinlock.o
271endif
272
273emac-$(CONFIG_TI_DAVINCI_EMAC) := am35xx-emac.o
274obj-y += $(emac-m) $(emac-y)
275
276obj-y += common-board-devices.o twl-common.o