gcc_stm32f3.cmake 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. SET(CMAKE_C_FLAGS "-mthumb -fno-builtin -mcpu=cortex-m4 -mfpu=fpv4-sp-d16 -mfloat-abi=hard -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-m4 -mfpu=fpv4-sp-d16 -mfloat-abi=hard -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-m4 -mfloat-abi=hard -mfpu=fpv4-sp-d16 -g -Wa,--no-warn -x assembler-with-cpp" CACHE INTERNAL "asm compiler flags")
  4. SET(CMAKE_EXE_LINKER_FLAGS "-Wl,--gc-sections -mthumb -mcpu=cortex-m4 -mfpu=fpv4-sp-d16 -mfloat-abi=hard" CACHE INTERNAL "executable linker flags")
  5. SET(CMAKE_MODULE_LINKER_FLAGS "-mthumb -mcpu=cortex-m4 -mfloat-abi=hard -mfpu=fpv4-sp-d16" CACHE INTERNAL "module linker flags")
  6. SET(CMAKE_SHARED_LINKER_FLAGS "-mthumb -mcpu=cortex-m4 -mfloat-abi=hard -mfpu=fpv4-sp-d16" CACHE INTERNAL "shared linker flags")
  7. SET(STM32_CHIP_TYPES 301xx 302xx 303xx 334xx 373xx CACHE INTERNAL "stm32f3 chip types")
  8. SET(STM32_CODES "301.." "302.." "303.." "334.." "373..")
  9. MACRO(STM32_GET_CHIP_TYPE CHIP CHIP_TYPE)
  10. STRING(REGEX REPLACE "^[sS][tT][mM]32[fF](3[037][1234].[68BC]).*$" "\\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 CCRAM_SIZE)
  22. STRING(REGEX REPLACE "^[sS][tT][mM]32[fF](3[037][1234].[68BC]).*$" "\\1" STM32_CODE ${CHIP})
  23. STRING(REGEX REPLACE "^[sS][tT][mM]32[fF]3[037][1234].([68BC]).*$" "\\1" STM32_SIZE_CODE ${CHIP})
  24. IF(STM32_SIZE_CODE STREQUAL "6")
  25. SET(FLASH "32K")
  26. SET(CCRAM_SIZE_IN_K "4")
  27. ELSEIF(STM32_SIZE_CODE STREQUAL "8")
  28. SET(FLASH "64K")
  29. SET(CCRAM_SIZE_IN_K "4")
  30. ELSEIF(STM32_SIZE_CODE STREQUAL "B")
  31. SET(FLASH "128K")
  32. SET(CCRAM_SIZE_IN_K "8")
  33. ELSEIF(STM32_SIZE_CODE STREQUAL "C")
  34. SET(FLASH "256K")
  35. SET(CCRAM_SIZE_IN_K "8")
  36. ENDIF()
  37. STM32_GET_CHIP_TYPE(${CHIP} TYPE)
  38. IF(${TYPE} STREQUAL "301xx")
  39. SET(RAM_SIZE_IN_K "16")
  40. ELSEIF(${TYPE} STREQUAL "302xx")
  41. SET(RAM_SIZE_IN_K "256")
  42. ELSEIF(${TYPE} STREQUAL "303xx")
  43. SET(RAM_SIZE_IN_K "48")
  44. ELSEIF(${TYPE} STREQUAL "334xx")
  45. SET(RAM_SIZE_IN_K "16")
  46. ELSEIF(${TYPE} STREQUAL "373xx")
  47. SET(RAM_SIZE_IN_K "128")
  48. ENDIF()
  49. # RAM size = total RAM - CCRAM
  50. MATH(EXPR RAM_SIZE_IN_K "${RAM_SIZE_IN_K}-${CCRAM_SIZE_IN_K}")
  51. # Append the 'K' literal to the numbers
  52. SET(RAM "${RAM_SIZE_IN_K}K")
  53. SET(CCRAM "${CCRAM_SIZE_IN_K}K")
  54. SET(${FLASH_SIZE} ${FLASH})
  55. SET(${RAM_SIZE} ${RAM})
  56. SET(${CCRAM_SIZE} ${CCRAM})
  57. ENDMACRO()
  58. FUNCTION(STM32_SET_CHIP_DEFINITIONS TARGET CHIP_TYPE)
  59. LIST(FIND STM32_CHIP_TYPES ${CHIP_TYPE} TYPE_INDEX)
  60. IF(TYPE_INDEX EQUAL -1)
  61. MESSAGE(FATAL_ERROR "Invalid/unsupported STM32F3 chip type: ${CHIP_TYPE}")
  62. ENDIF()
  63. GET_TARGET_PROPERTY(TARGET_DEFS ${TARGET} COMPILE_DEFINITIONS)
  64. STRING(REGEX REPLACE "^(3..).(.)" "\\1x\\2" CHIP_TYPE_2 ${STM32_CODE})
  65. IF(TARGET_DEFS)
  66. SET(TARGET_DEFS "STM32F3;STM32F${CHIP_TYPE_2};${TARGET_DEFS}")
  67. ELSE()
  68. SET(TARGET_DEFS "STM32F3;STM32F${CHIP_TYPE_2}")
  69. ENDIF()
  70. SET_TARGET_PROPERTIES(${TARGET} PROPERTIES COMPILE_DEFINITIONS "${TARGET_DEFS}")
  71. ENDFUNCTION()