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