ChibiOS3_LD.cmake 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738
  1. IF(NOT CHIBIOS_PROCESS_STACK_SIZE)
  2. SET(CHIBIOS_PROCESS_STACK_SIZE 0x400)
  3. MESSAGE(STATUS "No CHIBIOS_PROCESS_STACK_SIZE specified, using default: ${CHIBIOS_PROCESS_STACK_SIZE}")
  4. ENDIF()
  5. IF(NOT CHIBIOS_MAIN_STACK_SIZE)
  6. SET(CHIBIOS_MAIN_STACK_SIZE 0x400)
  7. MESSAGE(STATUS "No CHIBIOS_MAIN_STACK_SIZE specified, using default: ${CHIBIOS_MAIN_STACK_SIZE}")
  8. ENDIF()
  9. SET(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -L\"${CHIBIOS_ROOT}/os/common/ports/ARMCMx/compilers/GCC\"")
  10. SET(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -Wl,--defsym=__process_stack_size__=${CHIBIOS_PROCESS_STACK_SIZE}")
  11. SET(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -Wl,--defsym=__main_stack_size__=${CHIBIOS_MAIN_STACK_SIZE}")
  12. # Auto-generate linker script
  13. IF(NOT ChibiOS_LINKER_SCRIPT)
  14. FILE(WRITE ${CMAKE_BINARY_DIR}/chibios_link.ld.in
  15. "MEMORY\n"
  16. "{\n"
  17. " flash : org = 0x08000000, len = \${STM32_FLASH_SIZE}\n"
  18. " ram0 : org = 0x20000000, len = \${STM32_RAM_SIZE}\n"
  19. " ram1 : org = 0x00000000, len = 0\n"
  20. " ram2 : org = 0x00000000, len = 0\n"
  21. " ram3 : org = 0x00000000, len = 0\n"
  22. " ram4 : org = \${STM32_CCRAM_ORIGIN}, len = \${STM32_CCRAM_SIZE}\n"
  23. " ram5 : org = 0x00000000, len = 0\n"
  24. " ram6 : org = 0x00000000, len = 0\n"
  25. " ram7 : org = 0x00000000, len = 0\n"
  26. "}\n"
  27. "REGION_ALIAS(\"MAIN_STACK_RAM\", ram0);\n"
  28. "REGION_ALIAS(\"PROCESS_STACK_RAM\", ram0);\n"
  29. "REGION_ALIAS(\"DATA_RAM\", ram0);\n"
  30. "REGION_ALIAS(\"BSS_RAM\", ram0);\n"
  31. "REGION_ALIAS(\"HEAP_RAM\", ram0);\n"
  32. "INCLUDE rules.ld\n"
  33. )
  34. SET(ChibiOS_LINKER_SCRIPT ${CMAKE_BINARY_DIR}/chibios_link.ld.in)
  35. ENDIF()