Makefile 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. #
  2. # SPDX-License-Identifier: GPL-2.0+
  3. #
  4. ifeq ($(CONFIG_SPL_BUILD)$(CONFIG_TEGRA),yy)
  5. CONFIG_CPU_V7=
  6. CONFIG_CPU_ARM720T=y
  7. endif
  8. # This selects which instruction set is used.
  9. arch-$(CONFIG_CPU_ARM720T) =-march=armv4
  10. arch-$(CONFIG_CPU_ARM920T) =-march=armv4t
  11. arch-$(CONFIG_CPU_ARM926EJS) =-march=armv5te
  12. arch-$(CONFIG_CPU_ARM946ES) =-march=armv5te
  13. arch-$(CONFIG_CPU_SA1100) =-march=armv4
  14. arch-$(CONFIG_CPU_PXA) =
  15. arch-$(CONFIG_CPU_ARM1136) =-march=armv5
  16. arch-$(CONFIG_CPU_ARM1176) =-march=armv5t
  17. arch-$(CONFIG_CPU_V7) =$(call cc-option, -march=armv7-a, \
  18. $(call cc-option, -march=armv7, -march=armv5))
  19. arch-$(CONFIG_ARM64) =-march=armv8-a
  20. # On Tegra systems we must build SPL for the armv4 core on the device
  21. # but otherwise we can use the value in CONFIG_SYS_ARM_ARCH
  22. ifeq ($(CONFIG_SPL_BUILD)$(CONFIG_TEGRA),yy)
  23. arch-y += -D__LINUX_ARM_ARCH__=4
  24. else
  25. arch-y += -D__LINUX_ARM_ARCH__=$(CONFIG_SYS_ARM_ARCH)
  26. endif
  27. # Evaluate arch cc-option calls now
  28. arch-y := $(arch-y)
  29. # This selects how we optimise for the processor.
  30. tune-$(CONFIG_CPU_ARM720T) =-mtune=arm7tdmi
  31. tune-$(CONFIG_CPU_ARM920T) =
  32. tune-$(CONFIG_CPU_ARM926EJS) =
  33. tune-$(CONFIG_CPU_ARM946ES) =
  34. tune-$(CONFIG_CPU_SA1100) =-mtune=strongarm1100
  35. tune-$(CONFIG_CPU_PXA) =-mcpu=xscale
  36. tune-$(CONFIG_CPU_ARM1136) =
  37. tune-$(CONFIG_CPU_ARM1176) =
  38. tune-$(CONFIG_CPU_V7) =
  39. tune-$(CONFIG_ARM64) =
  40. # Evaluate tune cc-option calls now
  41. tune-y := $(tune-y)
  42. PLATFORM_CPPFLAGS += $(arch-y) $(tune-y)
  43. # Machine directory name. This list is sorted alphanumerically
  44. # by CONFIG_* macro name.
  45. machine-$(CONFIG_ARCH_AT91) += at91
  46. machine-$(CONFIG_ARCH_BCM283X) += bcm283x
  47. machine-$(CONFIG_ARCH_DAVINCI) += davinci
  48. machine-$(CONFIG_ARCH_EXYNOS) += exynos
  49. machine-$(CONFIG_ARCH_HIGHBANK) += highbank
  50. machine-$(CONFIG_ARCH_KEYSTONE) += keystone
  51. # TODO: rename CONFIG_KIRKWOOD -> CONFIG_ARCH_KIRKWOOD
  52. machine-$(CONFIG_KIRKWOOD) += kirkwood
  53. machine-$(CONFIG_LITESOM) += litesom
  54. machine-$(CONFIG_ARCH_MESON) += meson
  55. machine-$(CONFIG_ARCH_MVEBU) += mvebu
  56. # TODO: rename CONFIG_TEGRA -> CONFIG_ARCH_TEGRA
  57. # TODO: rename CONFIG_ORION5X -> CONFIG_ARCH_ORION5X
  58. machine-$(CONFIG_ORION5X) += orion5x
  59. machine-$(CONFIG_ARCH_OMAP2) += omap2
  60. machine-$(CONFIG_ARCH_S5PC1XX) += s5pc1xx
  61. machine-$(CONFIG_ARCH_SUNXI) += sunxi
  62. machine-$(CONFIG_ARCH_SNAPDRAGON) += snapdragon
  63. machine-$(CONFIG_ARCH_SOCFPGA) += socfpga
  64. machine-$(CONFIG_ARCH_RMOBILE) += rmobile
  65. machine-$(CONFIG_ARCH_ROCKCHIP) += rockchip
  66. machine-$(CONFIG_STM32) += stm32
  67. machine-$(CONFIG_TEGRA) += tegra
  68. machine-$(CONFIG_ARCH_UNIPHIER) += uniphier
  69. machine-$(CONFIG_ARCH_ZYNQ) += zynq
  70. machdirs := $(patsubst %,arch/arm/mach-%/,$(machine-y))
  71. PLATFORM_CPPFLAGS += $(patsubst %,-I$(srctree)/%include,$(machdirs))
  72. libs-y += $(machdirs)
  73. head-y := arch/arm/cpu/$(CPU)/start.o
  74. ifeq ($(CONFIG_SPL_BUILD),y)
  75. ifneq ($(CONFIG_SPL_START_S_PATH),)
  76. head-y := $(CONFIG_SPL_START_S_PATH:"%"=%)/start.o
  77. endif
  78. endif
  79. libs-y += arch/arm/cpu/$(CPU)/
  80. libs-y += arch/arm/cpu/
  81. libs-y += arch/arm/lib/
  82. ifeq ($(CONFIG_SPL_BUILD),y)
  83. ifneq (,$(CONFIG_MX23)$(CONFIG_MX28)$(CONFIG_MX35)$(filter $(SOC), mx25 mx5 mx6 mx7 mx35))
  84. libs-y += arch/arm/imx-common/
  85. endif
  86. else
  87. ifneq (,$(filter $(SOC), mx25 mx27 mx5 mx6 mx7 mx31 mx35 mxs vf610))
  88. libs-y += arch/arm/imx-common/
  89. endif
  90. endif
  91. ifneq (,$(filter $(SOC), kirkwood))
  92. libs-y += arch/arm/mach-mvebu/
  93. endif
  94. # deprecated
  95. -include $(machdirs)/config.mk