gcc_stm32f1.cmake 4.9 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 100xE 101x6 101xB 101xE 101xG 102x6 102xB 103x6 103xB 103xE 103xG 105xC 107xC CACHE INTERNAL "stm32f1 chip types")
  8. SET(STM32_CODES "100.[468B]" "100.[CDE]" "101.[46]" "101.[8B]" "101.[CDE]" "101.[FG]" "102.[46]" "102.[8B]" "103.[46]" "103.[8B]" "103.[CDE]" "103.[FG]" "105.[8BC]" "107.[BC]")
  9. MACRO(STM32_GET_CHIP_TYPE CHIP CHIP_TYPE)
  10. STRING(REGEX REPLACE "^[sS][tT][mM]32[fF](10[012357].[468BCDEFG]).+$" "\\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[fF](10[012357]).[468BCDEFG]" "\\1" STM32_CODE ${CHIP})
  23. STRING(REGEX REPLACE "^[sS][tT][mM]32[fF]10[012357].([468BCDEFG])" "\\1" STM32_SIZE_CODE ${CHIP})
  24. IF(STM32_SIZE_CODE STREQUAL "4")
  25. SET(FLASH "16K")
  26. ELSEIF(STM32_SIZE_CODE STREQUAL "6")
  27. SET(FLASH "32K")
  28. ELSEIF(STM32_SIZE_CODE STREQUAL "8")
  29. SET(FLASH "64K")
  30. ELSEIF(STM32_SIZE_CODE STREQUAL "B")
  31. SET(FLASH "128K")
  32. ELSEIF(STM32_SIZE_CODE STREQUAL "C")
  33. SET(FLASH "256K")
  34. ELSEIF(STM32_SIZE_CODE STREQUAL "D")
  35. SET(FLASH "384K")
  36. ELSEIF(STM32_SIZE_CODE STREQUAL "E")
  37. SET(FLASH "512K")
  38. ELSEIF(STM32_SIZE_CODE STREQUAL "F")
  39. SET(FLASH "768K")
  40. ELSEIF(STM32_SIZE_CODE STREQUAL "G")
  41. SET(FLASH "1024K")
  42. ENDIF()
  43. STM32_GET_CHIP_TYPE(${CHIP} TYPE)
  44. IF(${TYPE} STREQUAL 100xB)
  45. IF((STM32_SIZE_CODE STREQUAL "4") OR (STM32_SIZE_CODE STREQUAL "6"))
  46. SET(RAM "4K")
  47. ELSE()
  48. SET(RAM "8K")
  49. ENDIF()
  50. ELSEIF(${TYPE} STREQUAL 100xE)
  51. IF(STM32_SIZE_CODE STREQUAL "C")
  52. SET(RAM "24K")
  53. ELSE()
  54. SET(RAM "32K")
  55. ENDIF()
  56. ELSEIF(${TYPE} STREQUAL 101x6)
  57. IF(STM32_SIZE_CODE STREQUAL "4")
  58. SET(RAM "4K")
  59. ELSE()
  60. SET(RAM "6K")
  61. ENDIF()
  62. ELSEIF(${TYPE} STREQUAL 101xB)
  63. IF(STM32_SIZE_CODE STREQUAL "8")
  64. SET(RAM "10K")
  65. ELSE()
  66. SET(RAM "16K")
  67. ENDIF()
  68. ELSEIF(${TYPE} STREQUAL 101xE)
  69. IF(STM32_SIZE_CODE STREQUAL "C")
  70. SET(RAM "32K")
  71. ELSE()
  72. SET(RAM "48K")
  73. ENDIF()
  74. ELSEIF(${TYPE} STREQUAL 101xG)
  75. SET(RAM "80K")
  76. ELSEIF(${TYPE} STREQUAL 102x6)
  77. IF(STM32_SIZE_CODE STREQUAL "4")
  78. SET(RAM "4K")
  79. ELSE()
  80. SET(RAM "6K")
  81. ENDIF()
  82. ELSEIF(${TYPE} STREQUAL 102xB)
  83. IF(STM32_SIZE_CODE STREQUAL "8")
  84. SET(RAM "10K")
  85. ELSE()
  86. SET(RAM "16K")
  87. ENDIF()
  88. ELSEIF(${TYPE} STREQUAL 103x6)
  89. IF(STM32_SIZE_CODE STREQUAL "4")
  90. SET(RAM "6K")
  91. ELSE()
  92. SET(RAM "10K")
  93. ENDIF()
  94. ELSEIF(${TYPE} STREQUAL 103xB)
  95. SET(RAM "20K")
  96. ELSEIF(${TYPE} STREQUAL 103xE)
  97. IF(STM32_SIZE_CODE STREQUAL "C")
  98. SET(RAM "48K")
  99. ELSE()
  100. SET(RAM "54K")
  101. ENDIF()
  102. ELSEIF(${TYPE} STREQUAL 103xG)
  103. SET(RAM "96K")
  104. ELSEIF(${TYPE} STREQUAL 105xC)
  105. SET(RAM "64K")
  106. ELSEIF(${TYPE} STREQUAL 107xC)
  107. SET(RAM "64K")
  108. ENDIF()
  109. SET(${FLASH_SIZE} ${FLASH})
  110. SET(${RAM_SIZE} ${RAM})
  111. ENDMACRO()
  112. FUNCTION(STM32_SET_CHIP_DEFINITIONS TARGET CHIP_TYPE)
  113. LIST(FIND STM32_CHIP_TYPES ${CHIP_TYPE} TYPE_INDEX)
  114. IF(TYPE_INDEX EQUAL -1)
  115. MESSAGE(FATAL_ERROR "Invalid/unsupported STM32F1 chip type: ${CHIP_TYPE}")
  116. ENDIF()
  117. GET_TARGET_PROPERTY(TARGET_DEFS ${TARGET} COMPILE_DEFINITIONS)
  118. IF(TARGET_DEFS)
  119. SET(TARGET_DEFS "STM32F1;STM32F${CHIP_TYPE};${TARGET_DEFS}")
  120. ELSE()
  121. SET(TARGET_DEFS "STM32F1;STM32F${CHIP_TYPE}")
  122. ENDIF()
  123. SET_TARGET_PROPERTIES(${TARGET} PROPERTIES COMPILE_DEFINITIONS "${TARGET_DEFS}")
  124. ENDFUNCTION()