Merge tag 'qcom-dts-for-5.9' of git://git.kernel.org/pub/scm/linux/kernel/git/qcom...
[linux-2.6-microblaze.git] / arch / arm / mach-omap2 / Makefile
1 # SPDX-License-Identifier: GPL-2.0
2 #
3 # Makefile for the linux kernel.
4 #
5
6 ccflags-y := -I$(srctree)/$(src)/include \
7         -I$(srctree)/arch/arm/plat-omap/include
8
9 # Common support
10 obj-y := id.o io.o control.o devices.o fb.o pm.o \
11          common.o dma.o wd_timer.o display.o i2c.o hdq1w.o omap_hwmod.o \
12          omap_device.o omap-headsmp.o sram.o
13
14 hwmod-common                            = omap_hwmod.o omap_hwmod_reset.o \
15                                           omap_hwmod_common_data.o
16 clock-common                            = clock.o
17 secure-common                           = omap-smc.o omap-secure.o
18
19 obj-$(CONFIG_ARCH_OMAP2) += $(omap-2-3-common) $(hwmod-common)
20 obj-$(CONFIG_ARCH_OMAP3) += $(omap-2-3-common) $(hwmod-common) $(secure-common)
21 obj-$(CONFIG_ARCH_OMAP4) += $(hwmod-common) $(secure-common)
22 obj-$(CONFIG_SOC_AM33XX) += $(hwmod-common) $(secure-common)
23 obj-$(CONFIG_SOC_OMAP5)  += $(hwmod-common) $(secure-common)
24 obj-$(CONFIG_SOC_AM43XX) += $(hwmod-common) $(secure-common)
25 obj-$(CONFIG_SOC_DRA7XX) += $(hwmod-common) $(secure-common)
26
27 ifneq ($(CONFIG_SND_SOC_OMAP_MCBSP),)
28 obj-y += mcbsp.o
29 endif
30
31 obj-$(CONFIG_TWL4030_CORE) += omap_twl.o
32
33 ifneq ($(CONFIG_MFD_CPCAP),)
34 obj-y                                   += pmic-cpcap.o
35 endif
36
37 obj-$(CONFIG_SOC_HAS_OMAP2_SDRC)        += sdrc.o
38
39 # SMP support ONLY available for OMAP4
40
41 smp-$(CONFIG_SMP)                       += omap-smp.o
42 smp-$(CONFIG_HOTPLUG_CPU)               += omap-hotplug.o
43 omap-4-5-common                         =  omap4-common.o omap-wakeupgen.o
44 obj-$(CONFIG_ARCH_OMAP4)                += $(omap-4-5-common) $(smp-y) sleep44xx.o
45 obj-$(CONFIG_SOC_OMAP5)                 += $(omap-4-5-common) $(smp-y) sleep44xx.o
46 obj-$(CONFIG_SOC_AM43XX)                += $(omap-4-5-common)
47 obj-$(CONFIG_SOC_DRA7XX)                += $(omap-4-5-common) $(smp-y) sleep44xx.o
48
49 omap5-dra7-common-$(CONFIG_SOC_HAS_REALTIME_COUNTER) =  timer.o
50 obj-$(CONFIG_SOC_OMAP5)                 += $(omap5-dra7-common-y)
51 obj-$(CONFIG_SOC_DRA7XX)                += $(omap5-dra7-common-y)
52
53 # Functions loaded to SRAM
54 obj-$(CONFIG_SOC_OMAP2420)              += sram242x.o
55 obj-$(CONFIG_SOC_OMAP2430)              += sram243x.o
56
57 # Restart code (OMAP4/5 currently in omap4-common.c)
58 obj-$(CONFIG_SOC_OMAP2420)              += omap2-restart.o
59 obj-$(CONFIG_SOC_OMAP2430)              += omap2-restart.o
60 obj-$(CONFIG_SOC_TI81XX)                += ti81xx-restart.o
61 obj-$(CONFIG_SOC_AM33XX)                += am33xx-restart.o
62 obj-$(CONFIG_SOC_AM43XX)                += omap4-restart.o
63 obj-$(CONFIG_ARCH_OMAP3)                += omap3-restart.o
64 obj-$(CONFIG_ARCH_OMAP4)                += omap4-restart.o
65 obj-$(CONFIG_SOC_OMAP5)                 += omap4-restart.o
66 obj-$(CONFIG_SOC_DRA7XX)                += omap4-restart.o
67
68 # SMS/SDRC
69 obj-$(CONFIG_ARCH_OMAP2)                += sdrc2xxx.o
70 # obj-$(CONFIG_ARCH_OMAP3)              += sdrc3xxx.o
71
72 # OPP table initialization
73 ifeq ($(CONFIG_PM_OPP),y)
74 obj-$(CONFIG_ARCH_OMAP3)                += opp3xxx_data.o
75 obj-$(CONFIG_ARCH_OMAP4)                += opp4xxx_data.o
76 endif
77
78 # Power Management
79 omap-4-5-pm-common                      = omap-mpuss-lowpower.o
80 obj-$(CONFIG_ARCH_OMAP4)                += $(omap-4-5-pm-common)
81 obj-$(CONFIG_SOC_OMAP5)                 += $(omap-4-5-pm-common)
82
83 ifeq ($(CONFIG_PM),y)
84 obj-$(CONFIG_ARCH_OMAP2)                += pm24xx.o
85 obj-$(CONFIG_ARCH_OMAP2)                += sleep24xx.o
86 obj-$(CONFIG_ARCH_OMAP3)                += pm34xx.o sleep34xx.o
87 omap-4-5-pm-common                      += pm44xx.o
88 obj-$(CONFIG_ARCH_OMAP4)                += $(omap-4-5-pm-common)
89 obj-$(CONFIG_SOC_OMAP5)                 += $(omap-4-5-pm-common)
90 obj-$(CONFIG_SOC_DRA7XX)                += $(omap-4-5-pm-common)
91 obj-$(CONFIG_SOC_AM33XX)                += pm33xx-core.o sleep33xx.o
92 obj-$(CONFIG_SOC_AM43XX)                += pm33xx-core.o sleep43xx.o
93 obj-$(CONFIG_PM_DEBUG)                  += pm-debug.o
94
95 obj-$(CONFIG_POWER_AVS_OMAP)            += sr_device.o
96 obj-$(CONFIG_POWER_AVS_OMAP_CLASS3)    += smartreflex-class3.o
97
98 endif
99
100 ifeq ($(CONFIG_CPU_IDLE),y)
101 obj-$(CONFIG_ARCH_OMAP3)                += cpuidle34xx.o
102 omap-4-5-idle-common                    =  cpuidle44xx.o
103 obj-$(CONFIG_ARCH_OMAP4)                += $(omap-4-5-idle-common)
104 obj-$(CONFIG_SOC_OMAP5)                 += $(omap-4-5-idle-common)
105 obj-$(CONFIG_SOC_DRA7XX)                += $(omap-4-5-idle-common)
106 endif
107
108 # PRCM
109 obj-y                                   += prm_common.o cm_common.o
110 obj-$(CONFIG_ARCH_OMAP2)                += prm2xxx_3xxx.o prm2xxx.o cm2xxx.o
111 obj-$(CONFIG_ARCH_OMAP3)                += prm2xxx_3xxx.o prm3xxx.o cm3xxx.o
112 obj-$(CONFIG_ARCH_OMAP3)                += vc3xxx_data.o vp3xxx_data.o
113 omap-prcm-4-5-common                    =  cminst44xx.o prm44xx.o \
114                                            prcm_mpu44xx.o prminst44xx.o \
115                                            vc44xx_data.o vp44xx_data.o
116 obj-$(CONFIG_ARCH_OMAP4)                += $(omap-prcm-4-5-common)
117 obj-$(CONFIG_SOC_OMAP5)                 += $(omap-prcm-4-5-common)
118 obj-$(CONFIG_SOC_DRA7XX)                += $(omap-prcm-4-5-common)
119 am33xx-43xx-prcm-common                 += prm33xx.o cm33xx.o
120 obj-$(CONFIG_SOC_TI81XX)                += $(am33xx-43xx-prcm-common)
121 obj-$(CONFIG_SOC_AM33XX)                += $(am33xx-43xx-prcm-common)
122 obj-$(CONFIG_SOC_AM43XX)                += $(omap-prcm-4-5-common) \
123                                            $(am33xx-43xx-prcm-common)
124
125 # OMAP voltage domains
126 voltagedomain-common                    := voltage.o vc.o vp.o
127 obj-$(CONFIG_ARCH_OMAP2)                += $(voltagedomain-common)
128 obj-$(CONFIG_ARCH_OMAP2)                += voltagedomains2xxx_data.o
129 obj-$(CONFIG_ARCH_OMAP3)                += $(voltagedomain-common)
130 obj-$(CONFIG_ARCH_OMAP3)                += voltagedomains3xxx_data.o
131 obj-$(CONFIG_ARCH_OMAP4)                += $(voltagedomain-common)
132 obj-$(CONFIG_ARCH_OMAP4)                += voltagedomains44xx_data.o
133 obj-$(CONFIG_SOC_AM33XX)                += $(voltagedomain-common)
134 obj-$(CONFIG_SOC_AM43XX)                += $(voltagedomain-common)
135 obj-$(CONFIG_SOC_OMAP5)                 += $(voltagedomain-common)
136 obj-$(CONFIG_SOC_OMAP5)                += voltagedomains54xx_data.o
137 obj-$(CONFIG_SOC_DRA7XX)                += $(voltagedomain-common)
138
139 # OMAP powerdomain framework
140 powerdomain-common                      += powerdomain.o powerdomain-common.o
141 obj-$(CONFIG_ARCH_OMAP2)                += $(powerdomain-common)
142 obj-$(CONFIG_ARCH_OMAP2)                += powerdomains2xxx_data.o
143 obj-$(CONFIG_ARCH_OMAP2)                += powerdomains2xxx_3xxx_data.o
144 obj-$(CONFIG_ARCH_OMAP3)                += $(powerdomain-common)
145 obj-$(CONFIG_ARCH_OMAP3)                += powerdomains3xxx_data.o
146 obj-$(CONFIG_ARCH_OMAP3)                += powerdomains2xxx_3xxx_data.o
147 obj-$(CONFIG_ARCH_OMAP4)                += $(powerdomain-common)
148 obj-$(CONFIG_ARCH_OMAP4)                += powerdomains44xx_data.o
149 obj-$(CONFIG_SOC_AM33XX)                += $(powerdomain-common)
150 obj-$(CONFIG_SOC_AM33XX)                += powerdomains33xx_data.o
151 obj-$(CONFIG_SOC_AM43XX)                += $(powerdomain-common)
152 obj-$(CONFIG_SOC_AM43XX)                += powerdomains43xx_data.o
153 obj-$(CONFIG_SOC_OMAP5)                 += $(powerdomain-common)
154 obj-$(CONFIG_SOC_OMAP5)                 += powerdomains54xx_data.o
155 obj-$(CONFIG_SOC_DRA7XX)                += $(powerdomain-common)
156 obj-$(CONFIG_SOC_DRA7XX)                += powerdomains7xx_data.o
157
158 # PRCM clockdomain control
159 clockdomain-common                      += clockdomain.o
160 obj-$(CONFIG_ARCH_OMAP2)                += $(clockdomain-common)
161 obj-$(CONFIG_ARCH_OMAP2)                += clockdomains2xxx_3xxx_data.o
162 obj-$(CONFIG_SOC_OMAP2420)              += clockdomains2420_data.o
163 obj-$(CONFIG_SOC_OMAP2430)              += clockdomains2430_data.o
164 obj-$(CONFIG_ARCH_OMAP3)                += $(clockdomain-common)
165 obj-$(CONFIG_ARCH_OMAP3)                += clockdomains2xxx_3xxx_data.o
166 obj-$(CONFIG_ARCH_OMAP3)                += clockdomains3xxx_data.o
167 obj-$(CONFIG_ARCH_OMAP4)                += $(clockdomain-common)
168 obj-$(CONFIG_ARCH_OMAP4)                += clockdomains44xx_data.o
169 obj-$(CONFIG_SOC_AM33XX)                += $(clockdomain-common)
170 obj-$(CONFIG_SOC_AM33XX)                += clockdomains33xx_data.o
171 obj-$(CONFIG_SOC_TI81XX)                += $(clockdomain-common)
172 obj-$(CONFIG_SOC_TI81XX)                += clockdomains81xx_data.o
173 obj-$(CONFIG_SOC_AM43XX)                += $(clockdomain-common)
174 obj-$(CONFIG_SOC_AM43XX)                += clockdomains43xx_data.o
175 obj-$(CONFIG_SOC_OMAP5)                 += $(clockdomain-common)
176 obj-$(CONFIG_SOC_OMAP5)                 += clockdomains54xx_data.o
177 obj-$(CONFIG_SOC_DRA7XX)                += $(clockdomain-common)
178 obj-$(CONFIG_SOC_DRA7XX)                += clockdomains7xx_data.o
179
180 # Clock framework
181 obj-$(CONFIG_ARCH_OMAP2)                += $(clock-common)
182 obj-$(CONFIG_ARCH_OMAP2)                += clkt2xxx_dpllcore.o
183 obj-$(CONFIG_ARCH_OMAP2)                += clkt2xxx_virt_prcm_set.o
184 obj-$(CONFIG_ARCH_OMAP2)                += clkt2xxx_dpll.o
185 obj-$(CONFIG_ARCH_OMAP3)                += $(clock-common)
186 obj-$(CONFIG_ARCH_OMAP4)                += $(clock-common)
187 obj-$(CONFIG_SOC_AM33XX)                += $(clock-common)
188 obj-$(CONFIG_SOC_OMAP5)                 += $(clock-common)
189 obj-$(CONFIG_SOC_DRA7XX)                += $(clock-common)
190 obj-$(CONFIG_SOC_AM43XX)                += $(clock-common)
191
192 # OMAP2 clock rate set data (old "OPP" data)
193 obj-$(CONFIG_SOC_OMAP2420)              += opp2420_data.o
194 obj-$(CONFIG_SOC_OMAP2430)              += opp2430_data.o
195
196 # hwmod data
197 obj-y                                   += omap_hwmod_common_ipblock_data.o
198 obj-$(CONFIG_SOC_OMAP2420)              += omap_hwmod_2xxx_ipblock_data.o
199 obj-$(CONFIG_SOC_OMAP2420)              += omap_hwmod_2xxx_3xxx_ipblock_data.o
200 obj-$(CONFIG_SOC_OMAP2420)              += omap_hwmod_2xxx_interconnect_data.o
201 obj-$(CONFIG_SOC_OMAP2420)              += omap_hwmod_2420_data.o
202 obj-$(CONFIG_SOC_OMAP2430)              += omap_hwmod_2xxx_ipblock_data.o
203 obj-$(CONFIG_SOC_OMAP2430)              += omap_hwmod_2xxx_3xxx_ipblock_data.o
204 obj-$(CONFIG_SOC_OMAP2430)              += omap_hwmod_2xxx_interconnect_data.o
205 obj-$(CONFIG_SOC_OMAP2430)              += omap_hwmod_2430_data.o
206 obj-$(CONFIG_ARCH_OMAP3)                += omap_hwmod_2xxx_3xxx_ipblock_data.o
207 obj-$(CONFIG_ARCH_OMAP3)                += omap_hwmod_3xxx_data.o
208 obj-$(CONFIG_SOC_AM33XX)                += omap_hwmod_33xx_data.o
209 obj-$(CONFIG_SOC_AM33XX)                += omap_hwmod_33xx_43xx_interconnect_data.o
210 obj-$(CONFIG_SOC_AM33XX)                += omap_hwmod_33xx_43xx_ipblock_data.o
211 obj-$(CONFIG_SOC_AM43XX)                += omap_hwmod_43xx_data.o
212 obj-$(CONFIG_SOC_AM43XX)                += omap_hwmod_33xx_43xx_interconnect_data.o
213 obj-$(CONFIG_SOC_AM43XX)                += omap_hwmod_33xx_43xx_ipblock_data.o
214 obj-$(CONFIG_SOC_TI81XX)                += omap_hwmod_81xx_data.o
215 obj-$(CONFIG_ARCH_OMAP4)                += omap_hwmod_44xx_data.o
216 obj-$(CONFIG_SOC_OMAP5)                 += omap_hwmod_54xx_data.o
217 obj-$(CONFIG_SOC_DRA7XX)                += omap_hwmod_7xx_data.o
218
219 # OMAP2420 MSDI controller integration support ("MMC")
220 obj-$(CONFIG_SOC_OMAP2420)              += msdi.o
221
222 # Specific board support
223 obj-$(CONFIG_MACH_OMAP_GENERIC)         += board-generic.o pdata-quirks.o
224 obj-$(CONFIG_MACH_NOKIA_N8X0)           += board-n8x0.o
225
226 # Platform specific device init code
227
228 obj-y                                   += omap_phy_internal.o
229
230 obj-$(CONFIG_MACH_OMAP2_TUSB6010)       += usb-tusb6010.o
231
232 $(obj)/pm-asm-offsets.h: $(obj)/pm-asm-offsets.s FORCE
233         $(call filechk,offsets,__TI_PM_ASM_OFFSETS_H__)
234
235 $(obj)/sleep33xx.o $(obj)/sleep43xx.o: $(obj)/pm-asm-offsets.h
236
237 targets += pm-asm-offsets.s
238 clean-files += pm-asm-offsets.h
239
240 obj-$(CONFIG_OMAP_IOMMU)                += omap-iommu.o