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