Merge branch 'x86-build-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git...
[pandora-kernel.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
63 obj-$(CONFIG_ARCH_OMAP3)                += pm34xx.o sleep34xx.o \
64                                            cpuidle34xx.o
65 obj-$(CONFIG_ARCH_OMAP4)                += pm44xx.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_OMAP3_TOUCHBOOK)      += board-omap3touchbook.o \
233                                            hsmmc.o
234 obj-$(CONFIG_MACH_OMAP_4430SDP)         += board-4430sdp.o \
235                                            hsmmc.o \
236                                            omap_phy_internal.o
237 obj-$(CONFIG_MACH_OMAP4_PANDA)          += board-omap4panda.o \
238                                            hsmmc.o \
239                                            omap_phy_internal.o
240
241 obj-$(CONFIG_MACH_OMAP3517EVM)          += board-am3517evm.o \
242                                            omap_phy_internal.o \
243
244 obj-$(CONFIG_MACH_CRANEBOARD)           += board-am3517crane.o
245
246 obj-$(CONFIG_MACH_SBC3530)              += board-omap3stalker.o \
247                                            hsmmc.o
248 obj-$(CONFIG_MACH_TI8168EVM)            += board-ti8168evm.o
249 # Platform specific device init code
250 usbfs-$(CONFIG_ARCH_OMAP_OTG)           := usb-fs.o
251 obj-y                                   += $(usbfs-m) $(usbfs-y)
252 obj-y                                   += usb-musb.o
253 obj-$(CONFIG_MACH_OMAP2_TUSB6010)       += usb-tusb6010.o
254 obj-y                                   += usb-host.o
255
256 onenand-$(CONFIG_MTD_ONENAND_OMAP2)     := gpmc-onenand.o
257 obj-y                                   += $(onenand-m) $(onenand-y)
258
259 nand-$(CONFIG_MTD_NAND_OMAP2)           := gpmc-nand.o
260 obj-y                                   += $(nand-m) $(nand-y)
261
262 smc91x-$(CONFIG_SMC91X)                 := gpmc-smc91x.o
263 obj-y                                   += $(smc91x-m) $(smc91x-y)
264
265 smsc911x-$(CONFIG_SMSC911X)             := gpmc-smsc911x.o
266 obj-y                                   += $(smsc911x-m) $(smsc911x-y)
267 obj-$(CONFIG_ARCH_OMAP4)                += hwspinlock.o
268
269 disp-$(CONFIG_OMAP2_DSS)                := display.o
270 obj-y                                   += $(disp-m) $(disp-y)
271
272 obj-y                                   += common-board-devices.o