Merge branch 'for-paul-38-rebased' of git://gitorious.org/linux-omap-dss2/linux
[~shefty/rdma-dev.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_ARCH_OMAP2420)             += sram242x.o
35 obj-$(CONFIG_ARCH_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_ARCH_OMAP2420)             += mux2420.o
44 obj-$(CONFIG_ARCH_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 voltage.o
63 obj-$(CONFIG_ARCH_OMAP3)                += pm34xx.o sleep34xx.o voltage.o \
64                                            cpuidle34xx.o pm_bus.o
65 obj-$(CONFIG_ARCH_OMAP4)                += pm44xx.o voltage.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
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 # XXX The presence of cm2xxx_3xxx.o on the line below is temporary and
83 # will be removed once the OMAP4 part of the codebase is converted to
84 # use OMAP4-specific PRCM functions.
85 obj-$(CONFIG_ARCH_OMAP4)                += prcm.o cm2xxx_3xxx.o cminst44xx.o \
86                                            cm44xx.o prcm_mpu44xx.o \
87                                            prminst44xx.o
88
89 # OMAP powerdomain framework
90 powerdomain-common                      += powerdomain.o powerdomain-common.o
91 obj-$(CONFIG_ARCH_OMAP2)                += $(powerdomain-common) \
92                                            powerdomain2xxx_3xxx.o \
93                                            powerdomains2xxx_data.o \
94                                            powerdomains2xxx_3xxx_data.o
95 obj-$(CONFIG_ARCH_OMAP3)                += $(powerdomain-common) \
96                                            powerdomain2xxx_3xxx.o \
97                                            powerdomains3xxx_data.o \
98                                            powerdomains2xxx_3xxx_data.o
99 obj-$(CONFIG_ARCH_OMAP4)                += $(powerdomain-common) \
100                                            powerdomain44xx.o \
101                                            powerdomains44xx_data.o
102
103 # PRCM clockdomain control
104 obj-$(CONFIG_ARCH_OMAP2)                += clockdomain.o \
105                                            clockdomains2xxx_3xxx_data.o
106 obj-$(CONFIG_ARCH_OMAP3)                += clockdomain.o \
107                                            clockdomains2xxx_3xxx_data.o
108 obj-$(CONFIG_ARCH_OMAP4)                += clockdomain.o \
109                                            clockdomains44xx_data.o
110 # Clock framework
111 obj-$(CONFIG_ARCH_OMAP2)                += $(clock-common) clock2xxx.o \
112                                            clkt2xxx_sys.o \
113                                            clkt2xxx_dpllcore.o \
114                                            clkt2xxx_virt_prcm_set.o \
115                                            clkt2xxx_apll.o clkt2xxx_osc.o
116 obj-$(CONFIG_ARCH_OMAP2420)             += clock2420_data.o
117 obj-$(CONFIG_ARCH_OMAP2430)             += clock2430.o clock2430_data.o
118 obj-$(CONFIG_ARCH_OMAP3)                += $(clock-common) clock3xxx.o \
119                                            clock34xx.o clkt34xx_dpll3m2.o \
120                                            clock3517.o clock36xx.o \
121                                            dpll3xxx.o clock3xxx_data.o
122 obj-$(CONFIG_ARCH_OMAP4)                += $(clock-common) clock44xx_data.o \
123                                            dpll3xxx.o
124
125 # OMAP2 clock rate set data (old "OPP" data)
126 obj-$(CONFIG_ARCH_OMAP2420)             += opp2420_data.o
127 obj-$(CONFIG_ARCH_OMAP2430)             += opp2430_data.o
128
129 # hwmod data
130 obj-$(CONFIG_ARCH_OMAP2420)             += omap_hwmod_2420_data.o
131 obj-$(CONFIG_ARCH_OMAP2430)             += omap_hwmod_2430_data.o
132 obj-$(CONFIG_ARCH_OMAP3)                += omap_hwmod_3xxx_data.o
133 obj-$(CONFIG_ARCH_OMAP4)                += omap_hwmod_44xx_data.o
134
135 # EMU peripherals
136 obj-$(CONFIG_OMAP3_EMU)                 += emu.o
137
138 obj-$(CONFIG_OMAP_MBOX_FWK)             += mailbox_mach.o
139 mailbox_mach-objs                       := mailbox.o
140
141 obj-$(CONFIG_OMAP_IOMMU)                += iommu2.o
142
143 iommu-$(CONFIG_OMAP_IOMMU)              := omap-iommu.o
144 obj-y                                   += $(iommu-m) $(iommu-y)
145
146 i2c-omap-$(CONFIG_I2C_OMAP)             := i2c.o
147 obj-y                                   += $(i2c-omap-m) $(i2c-omap-y)
148
149 ifneq ($(CONFIG_TIDSPBRIDGE),)
150 obj-y                                   += dsp.o
151 endif
152
153 # Specific board support
154 obj-$(CONFIG_MACH_OMAP_GENERIC)         += board-generic.o
155 obj-$(CONFIG_MACH_OMAP_H4)              += board-h4.o
156 obj-$(CONFIG_MACH_OMAP_2430SDP)         += board-2430sdp.o \
157                                            hsmmc.o
158 obj-$(CONFIG_MACH_OMAP_APOLLON)         += board-apollon.o
159 obj-$(CONFIG_MACH_OMAP3_BEAGLE)         += board-omap3beagle.o \
160                                            hsmmc.o
161 obj-$(CONFIG_MACH_DEVKIT8000)           += board-devkit8000.o \
162                                            hsmmc.o
163 obj-$(CONFIG_MACH_OMAP_LDP)             += board-ldp.o \
164                                            board-flash.o \
165                                            hsmmc.o
166 obj-$(CONFIG_MACH_OMAP3530_LV_SOM)      += board-omap3logic.o \
167                                            hsmmc.o
168 obj-$(CONFIG_MACH_OMAP3_TORPEDO)        += board-omap3logic.o \
169                                            hsmmc.o
170 obj-$(CONFIG_MACH_OVERO)                += board-overo.o \
171                                            hsmmc.o
172 obj-$(CONFIG_MACH_OMAP3EVM)             += board-omap3evm.o \
173                                            hsmmc.o
174 obj-$(CONFIG_MACH_OMAP3_PANDORA)        += board-omap3pandora.o \
175                                            hsmmc.o
176 obj-$(CONFIG_MACH_OMAP_3430SDP)         += board-3430sdp.o \
177                                            hsmmc.o \
178                                            board-flash.o
179 obj-$(CONFIG_MACH_NOKIA_N8X0)           += board-n8x0.o
180 obj-$(CONFIG_MACH_NOKIA_RM680)          += board-rm680.o \
181                                            sdram-nokia.o \
182                                            hsmmc.o
183 obj-$(CONFIG_MACH_NOKIA_RX51)           += board-rx51.o \
184                                            sdram-nokia.o \
185                                            board-rx51-peripherals.o \
186                                            board-rx51-video.o \
187                                            hsmmc.o
188 obj-$(CONFIG_MACH_OMAP_ZOOM2)           += board-zoom.o \
189                                            board-zoom-peripherals.o \
190                                            board-zoom-display.o \
191                                            board-flash.o \
192                                            hsmmc.o \
193                                            board-zoom-debugboard.o
194 obj-$(CONFIG_MACH_OMAP_ZOOM3)           += board-zoom.o \
195                                            board-zoom-peripherals.o \
196                                            board-zoom-display.o \
197                                            board-flash.o \
198                                            hsmmc.o \
199                                            board-zoom-debugboard.o
200 obj-$(CONFIG_MACH_OMAP_3630SDP)         += board-3630sdp.o \
201                                            board-zoom-peripherals.o \
202                                            board-zoom-display.o \
203                                            board-flash.o \
204                                            hsmmc.o
205 obj-$(CONFIG_MACH_CM_T35)               += board-cm-t35.o \
206                                            hsmmc.o
207 obj-$(CONFIG_MACH_CM_T3517)             += board-cm-t3517.o
208 obj-$(CONFIG_MACH_IGEP0020)             += board-igep0020.o \
209                                            hsmmc.o
210 obj-$(CONFIG_MACH_IGEP0030)             += board-igep0030.o \
211                                            hsmmc.o
212 obj-$(CONFIG_MACH_OMAP3_TOUCHBOOK)      += board-omap3touchbook.o \
213                                            hsmmc.o
214 obj-$(CONFIG_MACH_OMAP_4430SDP)         += board-4430sdp.o \
215                                            hsmmc.o \
216                                            omap_phy_internal.o
217 obj-$(CONFIG_MACH_OMAP4_PANDA)          += board-omap4panda.o \
218                                            hsmmc.o \
219                                            omap_phy_internal.o
220
221 obj-$(CONFIG_MACH_OMAP3517EVM)          += board-am3517evm.o
222
223 obj-$(CONFIG_MACH_CRANEBOARD)           += board-am3517crane.o
224
225 obj-$(CONFIG_MACH_SBC3530)              += board-omap3stalker.o \
226                                            hsmmc.o
227 # Platform specific device init code
228 usbfs-$(CONFIG_ARCH_OMAP_OTG)           := usb-fs.o
229 obj-y                                   += $(usbfs-m) $(usbfs-y)
230 obj-y                                   += usb-musb.o
231 obj-$(CONFIG_MACH_OMAP2_TUSB6010)       += usb-tusb6010.o
232 obj-y                                   += usb-ehci.o
233
234 onenand-$(CONFIG_MTD_ONENAND_OMAP2)     := gpmc-onenand.o
235 obj-y                                   += $(onenand-m) $(onenand-y)
236
237 nand-$(CONFIG_MTD_NAND_OMAP2)           := gpmc-nand.o
238 obj-y                                   += $(nand-m) $(nand-y)
239
240 smc91x-$(CONFIG_SMC91X)                 := gpmc-smc91x.o
241 obj-y                                   += $(smc91x-m) $(smc91x-y)
242
243 smsc911x-$(CONFIG_SMSC911X)             := gpmc-smsc911x.o
244 obj-y                                   += $(smsc911x-m) $(smsc911x-y)