Makefile 10.0 KB

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