You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

arch.cmake 4.6 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. ## Author: Hank Anderson <hank@statease.com>
  2. ## Description: Ported from portion of OpenBLAS/Makefile.system
  3. ## Sets various variables based on architecture.
  4. if (X86 OR X86_64)
  5. if (X86)
  6. if (NOT BINARY)
  7. set(NO_BINARY_MODE 1)
  8. endif ()
  9. endif ()
  10. if (NOT NO_EXPRECISION)
  11. if (${F_COMPILER} MATCHES "GFORTRAN")
  12. # N.B. I'm not sure if CMake differentiates between GCC and LSB -hpa
  13. if (${CMAKE_C_COMPILER_ID} STREQUAL "GNU" OR ${CMAKE_C_COMPILER_ID} STREQUAL "LSB")
  14. set(EXPRECISION 1)
  15. set(CCOMMON_OPT "${CCOMMON_OPT} -DEXPRECISION -m128bit-long-double")
  16. set(FCOMMON_OPT "${FCOMMON_OPT} -m128bit-long-double")
  17. endif ()
  18. if (${CMAKE_C_COMPILER_ID} STREQUAL "Clang")
  19. set(EXPRECISION 1)
  20. set(CCOMMON_OPT "${CCOMMON_OPT} -DEXPRECISION")
  21. set(FCOMMON_OPT "${FCOMMON_OPT} -m128bit-long-double")
  22. endif ()
  23. endif ()
  24. endif ()
  25. endif ()
  26. if (${CMAKE_C_COMPILER_ID} STREQUAL "Intel")
  27. set(CCOMMON_OPT "${CCOMMON_OPT} -wd981")
  28. endif ()
  29. if (DYNAMIC_ARCH)
  30. if (ARM64)
  31. set(DYNAMIC_CORE ARMV8 CORTEXA53 CORTEXA57 THUNDERX THUNDERX2T99 TSV110 EMAG8180 NEOVERSEN1 THUNDERX3T110)
  32. if (${CMAKE_C_COMPILER_ID} STREQUAL "GNU")
  33. if (${CMAKE_C_COMPILER_VERSION} VERSION_GREATER_EQUAL 10) # SVE ACLE supported in GCC >= 10
  34. set(DYNAMIC_CORE ${DYNAMIC_CORE} NEOVERSEV1 NEOVERSEN2 ARMV8SVE A64FX)
  35. endif ()
  36. if (${CMAKE_C_COMPILER_VERSION} VERSION_GREATER_EQUAL 14) # SME ACLE supported in GCC >= 14
  37. set(DYNAMIC_CORE ${DYNAMIC_CORE} ARMV9SME)
  38. endif()
  39. elseif (${CMAKE_C_COMPILER_ID} MATCHES "Clang")
  40. if (${CMAKE_C_COMPILER_VERSION} VERSION_GREATER_EQUAL 11) # SVE ACLE supported in LLVM >= 11
  41. set(DYNAMIC_CORE ${DYNAMIC_CORE} NEOVERSEV1 NEOVERSEN2 ARMV8SVE A64FX)
  42. endif ()
  43. if (${CMAKE_C_COMPILER_VERSION} VERSION_GREATER_EQUAL 19) # SME ACLE supported in LLVM >= 19
  44. set(DYNAMIC_CORE ${DYNAMIC_CORE} ARMV9SME)
  45. endif()
  46. endif ()
  47. if (DYNAMIC_LIST)
  48. set(DYNAMIC_CORE ARMV8 ${DYNAMIC_LIST})
  49. endif ()
  50. endif ()
  51. if (POWER)
  52. set(DYNAMIC_CORE POWER6 POWER8 POWER9 POWER10)
  53. set(CCOMMON_OPT "${CCOMMON_OPT} -DHAVE_P10_SUPPORT")
  54. endif ()
  55. if (RISCV64)
  56. set(DYNAMIC_CORE RISCV64_GENERIC RISCV64_ZVL128B RISCV64_ZVL256B)
  57. endif ()
  58. if (X86)
  59. set(DYNAMIC_CORE KATMAI COPPERMINE NORTHWOOD PRESCOTT BANIAS CORE2 PENRYN DUNNINGTON NEHALEM ATHLON OPTERON OPTERON_SSE3 BARCELONA BOBCAT ATOM NANO)
  60. endif ()
  61. if (X86_64)
  62. set(DYNAMIC_CORE PRESCOTT CORE2)
  63. if (DYNAMIC_OLDER)
  64. set (DYNAMIC_CORE ${DYNAMIC_CORE} PENRYN DUNNINGTON)
  65. endif ()
  66. set (DYNAMIC_CORE ${DYNAMIC_CORE} NEHALEM)
  67. if (DYNAMIC_OLDER)
  68. set (DYNAMIC_CORE ${DYNAMIC_CORE} OPTERON OPTERON_SSE3)
  69. endif ()
  70. set (DYNAMIC_CORE ${DYNAMIC_CORE} BARCELONA)
  71. if (DYNAMIC_OLDER)
  72. set (DYNAMIC_CORE ${DYNAMIC_CORE} BOBCAT ATOM NANO)
  73. endif ()
  74. if (NOT NO_AVX)
  75. set(DYNAMIC_CORE ${DYNAMIC_CORE} SANDYBRIDGE BULLDOZER PILEDRIVER STEAMROLLER EXCAVATOR)
  76. endif ()
  77. if (NOT NO_AVX2)
  78. set(DYNAMIC_CORE ${DYNAMIC_CORE} HASWELL ZEN)
  79. endif ()
  80. if (NOT NO_AVX512)
  81. set(DYNAMIC_CORE ${DYNAMIC_CORE} SKYLAKEX COOPERLAKE SAPPHIRERAPIDS)
  82. string(REGEX REPLACE "-march=native" "" CMAKE_C_FLAGS "${CMAKE_C_FLAGS}")
  83. endif ()
  84. if (DYNAMIC_LIST)
  85. set(DYNAMIC_CORE PRESCOTT ${DYNAMIC_LIST})
  86. endif ()
  87. endif ()
  88. if (LOONGARCH64)
  89. set(DYNAMIC_CORE LA64_GENERIC LA264 LA464)
  90. endif ()
  91. if (EXISTS ${PROJECT_SOURCE_DIR}/config_kernel.h)
  92. message (FATAL_ERROR "Your build directory contains a file config_kernel.h, probably from a previous compilation with make. This will conflict with the cmake compilation and cause strange compiler errors - please remove the file before trying again")
  93. endif ()
  94. if (NOT DYNAMIC_CORE)
  95. message (STATUS "DYNAMIC_ARCH is not supported on this architecture, removing from options")
  96. unset(DYNAMIC_ARCH CACHE)
  97. endif ()
  98. endif ()
  99. if (${ARCH} STREQUAL "ia64")
  100. set(NO_BINARY_MODE 1)
  101. set(BINARY_DEFINED 1)
  102. if (${F_COMPILER} MATCHES "GFORTRAN")
  103. if (${CMAKE_C_COMPILER_ID} STREQUAL "GNU")
  104. # EXPRECISION = 1
  105. # CCOMMON_OPT += -DEXPRECISION
  106. endif ()
  107. endif ()
  108. endif ()
  109. if (MIPS32 OR MIPS64)
  110. set(NO_BINARY_MODE 1)
  111. endif ()
  112. if (LOONGARCH64)
  113. set(NO_BINARY_MODE 1)
  114. endif ()
  115. if (${ARCH} STREQUAL "alpha")
  116. set(NO_BINARY_MODE 1)
  117. set(BINARY_DEFINED 1)
  118. endif ()
  119. if (ARM)
  120. set(NO_BINARY_MODE 1)
  121. set(BINARY_DEFINED 1)
  122. endif ()
  123. if (ARM64)
  124. set(NO_BINARY_MODE 1)
  125. set(BINARY_DEFINED 1)
  126. endif ()
  127. if (RISCV64)
  128. set(NO_BINARY_MODE 1)
  129. set(BINARY_DEFINED 1)
  130. endif ()