gcc_stm32l1.cmake 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. SET(CMAKE_C_FLAGS "-mthumb -fno-builtin -mcpu=cortex-m3 -Wall -std=gnu99 -ffunction-sections -fdata-sections -fomit-frame-pointer -mabi=aapcs -fno-unroll-loops -ffast-math -ftree-vectorize" CACHE INTERNAL "c compiler flags")
  2. SET(CMAKE_CXX_FLAGS "-mthumb -fno-builtin -mcpu=cortex-m3 -Wall -std=c++11 -ffunction-sections -fdata-sections -fomit-frame-pointer -mabi=aapcs -fno-unroll-loops -ffast-math -ftree-vectorize" CACHE INTERNAL "cxx compiler flags")
  3. SET(CMAKE_ASM_FLAGS "-mthumb -mcpu=cortex-m3 -x assembler-with-cpp" CACHE INTERNAL "asm compiler flags")
  4. SET(CMAKE_EXE_LINKER_FLAGS "-Wl,--gc-sections -mthumb -mcpu=cortex-m3 -mabi=aapcs" CACHE INTERNAL "executable linker flags")
  5. SET(CMAKE_MODULE_LINKER_FLAGS "-mthumb -mcpu=cortex-m3 -mabi=aapcs" CACHE INTERNAL "module linker flags")
  6. SET(CMAKE_SHARED_LINKER_FLAGS "-mthumb -mcpu=cortex-m3 -mabi=aapcs" CACHE INTERNAL "shared linker flags")
  7. SET(STM32_CHIP_TYPES 100xB 100xBA 100xC 151xB 151xBA 151xC 151xCA 151xD 151xDX 151xE 152xB 152xBA 152xC 152xCA 152xD 152xDX 152xE 162xC 162xCA 162xD 162xDX 162xE CACHE INTERNAL "stm32l1 chip types")
  8. SET(STM32_CODES "100.B" "100.BA" "100.C" "151.B" "151.BA" "151.C" "151.CA" "151.D" "151.DX" "151.E" "152.B" "152.BA" "152.C" "152.CA" "152.D" "152.DX" "152.E" "162.C" "162.CA" "162.D" "162.DX" "162.E")
  9. MACRO(STM32_GET_CHIP_TYPE CHIP CHIP_TYPE)
  10. STRING(REGEX REPLACE "^[sS][tT][mM]32[lL]((100.[BC])|(100.[BC]A)|(15[12].[BCE])|(15[12].[BC]A)|(15[12].DX)|(162.[EDC])|(162.CA)|(162.DX)).+$" "\\1" STM32_CODE ${CHIP})
  11. SET(INDEX 0)
  12. FOREACH(C_TYPE ${STM32_CHIP_TYPES})
  13. LIST(GET STM32_CODES ${INDEX} CHIP_TYPE_REGEXP)
  14. IF(STM32_CODE MATCHES ${CHIP_TYPE_REGEXP})
  15. SET(RESULT_TYPE ${C_TYPE})
  16. ENDIF()
  17. MATH(EXPR INDEX "${INDEX}+1")
  18. ENDFOREACH()
  19. SET(${CHIP_TYPE} ${RESULT_TYPE})
  20. ENDMACRO()
  21. MACRO(STM32_GET_CHIP_PARAMETERS CHIP FLASH_SIZE RAM_SIZE)
  22. STRING(REGEX REPLACE "^[sS][tT][mM]32[lL](1[056][012]).([68BCDE]$|[68BCDE][AX]$)" "\\1" STM32_CODE ${CHIP})
  23. STRING(REGEX REPLACE "^[sS][tT][mM]32[lL](1[056][012]).([68BCDE]$|[68BCDE][AX]$)" "\\2" STM32_SIZE_CODE ${CHIP})
  24. IF(STM32_SIZE_CODE STREQUAL "6" OR STM32_SIZE_CODE STREQUAL "6A")
  25. SET(FLASH "32K")
  26. ELSEIF(STM32_SIZE_CODE STREQUAL "8" OR STM32_SIZE_CODE STREQUAL "8A")
  27. SET(FLASH "64K")
  28. ELSEIF(STM32_SIZE_CODE STREQUAL "B" OR STM32_SIZE_CODE STREQUAL "BA")
  29. SET(FLASH "128K")
  30. ELSEIF(STM32_SIZE_CODE STREQUAL "C" OR STM32_SIZE_CODE STREQUAL "CA")
  31. SET(FLASH "256K")
  32. ELSEIF(STM32_SIZE_CODE STREQUAL "D" OR STM32_SIZE_CODE STREQUAL "DX")
  33. SET(FLASH "384K")
  34. ELSEIF(STM32_SIZE_CODE STREQUAL "E")
  35. SET(FLASH "512K")
  36. ENDIF()
  37. STM32_GET_CHIP_TYPE(${CHIP} TYPE)
  38. IF(${TYPE} STREQUAL 100xB)
  39. SET(RAM "10K")
  40. SET(FLASH "128K")
  41. ELSEIF(${TYPE} STREQUAL 100xBA)
  42. SET(RAM "16K")
  43. SET(FLASH "128K")
  44. ELSEIF(${TYPE} STREQUAL 100xC)
  45. SET(RAM "16K")
  46. SET(FLASH "256K")
  47. ELSEIF(${TYPE} STREQUAL 151xB)
  48. SET(RAM "16K")
  49. SET(FLASH "128K")
  50. ELSEIF(${TYPE} STREQUAL 151xBA)
  51. SET(RAM "32K")
  52. SET(FLASH "128K")
  53. ELSEIF(${TYPE} STREQUAL 151xC)
  54. SET(RAM "32K")
  55. SET(FLASH "256K")
  56. ELSEIF(${TYPE} STREQUAL 151xCA)
  57. SET(RAM "32K")
  58. SET(FLASH "256K")
  59. ELSEIF(${TYPE} STREQUAL 151xD)
  60. SET(RAM "48K")
  61. SET(FLASH "384K")
  62. ELSEIF(${TYPE} STREQUAL 151xDX)
  63. SET(RAM "80K")
  64. SET(FLASH "384K")
  65. ELSEIF(${TYPE} STREQUAL 151xE)
  66. SET(RAM "80K")
  67. SET(FLASH "512K")
  68. ELSEIF(${TYPE} STREQUAL 152xB)
  69. SET(RAM "16K")
  70. SET(FLASH "128K")
  71. ELSEIF(${TYPE} STREQUAL 152xBA)
  72. SET(RAM "32K")
  73. SET(FLASH "128K")
  74. ELSEIF(${TYPE} STREQUAL 152xC)
  75. SET(RAM "32K")
  76. SET(FLASH "256K")
  77. ELSEIF(${TYPE} STREQUAL 152xCA)
  78. SET(RAM "32K")
  79. SET(FLASH "256K")
  80. ELSEIF(${TYPE} STREQUAL 152xD)
  81. SET(RAM "48K")
  82. SET(FLASH "384K")
  83. ELSEIF(${TYPE} STREQUAL 152xDX)
  84. SET(RAM "80K")
  85. SET(FLASH "384K")
  86. ELSEIF(${TYPE} STREQUAL 152xE)
  87. SET(RAM "80K")
  88. SET(FLASH "512K")
  89. ELSEIF(${TYPE} STREQUAL 162xC)
  90. SET(RAM "32K")
  91. SET(FLASH "256K")
  92. ELSEIF(${TYPE} STREQUAL 162xCA)
  93. SET(RAM "32K")
  94. SET(FLASH "256K")
  95. ELSEIF(${TYPE} STREQUAL 162xD)
  96. SET(RAM "48K")
  97. SET(FLASH "384K")
  98. ELSEIF(${TYPE} STREQUAL 162xDX)
  99. SET(RAM "80K")
  100. SET(FLASH "384K")
  101. ELSEIF(${TYPE} STREQUAL 162xE)
  102. SET(RAM "80K")
  103. SET(FLASH "512K")
  104. ENDIF()
  105. SET(${FLASH_SIZE} ${FLASH})
  106. SET(${RAM_SIZE} ${RAM})
  107. ENDMACRO()
  108. FUNCTION(STM32_SET_CHIP_DEFINITIONS TARGET CHIP_TYPE)
  109. LIST(FIND STM32_CHIP_TYPES ${CHIP_TYPE} TYPE_INDEX)
  110. IF(TYPE_INDEX EQUAL -1)
  111. MESSAGE(FATAL_ERROR "Invalid/unsupported STM32L1 chip type: ${CHIP_TYPE}")
  112. ENDIF()
  113. GET_TARGET_PROPERTY(TARGET_DEFS ${TARGET} COMPILE_DEFINITIONS)
  114. IF(TARGET_DEFS)
  115. SET(TARGET_DEFS "STM32L${CHIP_TYPE};${TARGET_DEFS}")
  116. ELSE()
  117. SET(TARGET_DEFS "STM32L${CHIP_TYPE}")
  118. ENDIF()
  119. SET_TARGET_PROPERTIES(${TARGET} PROPERTIES COMPILE_DEFINITIONS "${TARGET_DEFS}")
  120. ENDFUNCTION()