gcc_stm32f2.cmake 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  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 205xB 205xC 205xE 205xF 205xG 215xE 215xG 207xC 207xE 207xF 207xG 217xE 217xG)
  8. SET(STM32_CODES "205.B" "205.C" "205.E" "205.F" "205.G" "215.E" "215.G" "207.C" "207.E" "207.F" "207.G" "217.E" "217.G")
  9. MACRO(STM32_GET_CHIP_TYPE CHIP CHIP_TYPE)
  10. STRING(REGEX REPLACE "^[sS][tT][mM]32[fF](2[01]7.[BCDEFG]).+$" "\\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]2[01]7.([BCDEFG])" "\\1" STM32_SIZE_CODE ${CHIP})
  23. IF(STM32_SIZE_CODE STREQUAL "B")
  24. SET(FLASH "128K")
  25. ELSEIF(STM32_SIZE_CODE STREQUAL "C")
  26. SET(FLASH "256K")
  27. ELSEIF(STM32_SIZE_CODE STREQUAL "D")
  28. SET(FLASH "384K")
  29. ELSEIF(STM32_SIZE_CODE STREQUAL "E")
  30. SET(FLASH "512K")
  31. ELSEIF(STM32_SIZE_CODE STREQUAL "F")
  32. SET(FLASH "768K")
  33. ELSEIF(STM32_SIZE_CODE STREQUAL "G")
  34. SET(FLASH "1024K")
  35. ENDIF()
  36. STM32_GET_CHIP_TYPE(${CHIP} TYPE)
  37. SET(RAM "128K")
  38. IF(${TYPE} STREQUAL 205xC)
  39. SET(RAM "96K")
  40. ELSEIF(${TYPE} STREQUAL 205xB)
  41. SET(RAM "64K")
  42. ENDIF()
  43. SET(${FLASH_SIZE} ${FLASH})
  44. SET(${RAM_SIZE} ${RAM})
  45. ENDMACRO()
  46. FUNCTION(STM32_SET_CHIP_DEFINITIONS TARGET CHIP_TYPE)
  47. LIST(FIND STM32_CHIP_TYPES ${CHIP_TYPE} TYPE_INDEX)
  48. IF(TYPE_INDEX EQUAL -1)
  49. MESSAGE(FATAL_ERROR "Invalid/unsupported STM32F2 chip type: ${CHIP_TYPE}")
  50. ENDIF()
  51. STRING(REGEX REPLACE "^(2[01]7).[BCDEFG]" "\\1" DEVICE_NUM ${STM32_CHIP_TYPE})
  52. GET_TARGET_PROPERTY(TARGET_DEFS ${TARGET} COMPILE_DEFINITIONS)
  53. IF(TARGET_DEFS)
  54. SET(TARGET_DEFS "STM32F2;STM32F${DEVICE_NUM}xx;${TARGET_DEFS}")
  55. ELSE()
  56. SET(TARGET_DEFS "STM32F2;STM32F${DEVICE_NUM}xx")
  57. ENDIF()
  58. SET_TARGET_PROPERTIES(${TARGET} PROPERTIES COMPILE_DEFINITIONS "${TARGET_DEFS}")
  59. ENDFUNCTION()