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