Christophe Favergeon | 6b604eb | 2019-05-17 13:46:33 +0200 | [diff] [blame] | 1 | include(CMakePrintHelpers) |
Christophe Favergeon | 6b604eb | 2019-05-17 13:46:33 +0200 | [diff] [blame] | 2 | |
Christophe Favergeon | 6b604eb | 2019-05-17 13:46:33 +0200 | [diff] [blame] | 3 | |
| 4 | |
| 5 | get_filename_component(PROJECT_NAME ${CMAKE_CURRENT_SOURCE_DIR} NAME) |
| 6 | |
| 7 | cmake_print_variables(PROJECT_NAME) |
| 8 | |
Christophe Favergeon | 6b604eb | 2019-05-17 13:46:33 +0200 | [diff] [blame] | 9 | |
Christophe Favergeon | 26c2f68 | 2019-09-06 14:43:32 +0100 | [diff] [blame] | 10 | function(cortexm CORE PROJECT_NAME ROOT PLATFORMFOLDER CSTARTUP) |
Christophe Favergeon | 3b2a0ee | 2019-06-12 13:29:14 +0200 | [diff] [blame] | 11 | |
| 12 | target_include_directories(${PROJECT_NAME} PRIVATE ${ROOT}/CMSIS/Core/Include) |
| 13 | |
| 14 | target_sources(${PROJECT_NAME} PRIVATE ${PLATFORMFOLDER}/${CORE}/system_${CORE}.c) |
| 15 | |
Christophe Favergeon | 6b604eb | 2019-05-17 13:46:33 +0200 | [diff] [blame] | 16 | |
Christophe Favergeon | 26c2f68 | 2019-09-06 14:43:32 +0100 | [diff] [blame] | 17 | toolchainSpecificLinkForCortexM(${PROJECT_NAME} ${ROOT} ${CORE} ${PLATFORMFOLDER} ${CSTARTUP}) |
Christophe Favergeon | 3b2a0ee | 2019-06-12 13:29:14 +0200 | [diff] [blame] | 18 | |
| 19 | configplatformForApp(${PROJECT_NAME} ${ROOT} ${CORE} ${PLATFORMFOLDER}) |
| 20 | SET(PLATFORMID ${PLATFORMID} PARENT_SCOPE) |
| 21 | |
| 22 | endfunction() |
| 23 | |
| 24 | function(cortexa CORE PROJECT_NAME ROOT PLATFORMFOLDER) |
| 25 | target_include_directories(${PROJECT_NAME} PRIVATE ${ROOT}/CMSIS/Core_A/Include) |
| 26 | |
| 27 | target_sources(${PROJECT_NAME} PRIVATE ${PLATFORMFOLDER}/${CORE}/irq_ctrl_gic.c) |
| 28 | target_sources(${PROJECT_NAME} PRIVATE ${PLATFORMFOLDER}/${CORE}/mmu_${CORE}.c) |
| 29 | target_sources(${PROJECT_NAME} PRIVATE ${PLATFORMFOLDER}/${CORE}/system_${CORE}.c) |
| 30 | |
| 31 | |
| 32 | target_compile_definitions(${PROJECT_NAME} PRIVATE -DCMSIS_device_header="${CORE}.h") |
| 33 | |
| 34 | toolchainSpecificLinkForCortexA(${PROJECT_NAME} ${ROOT} ${CORE} ${PLATFORMFOLDER}) |
| 35 | |
| 36 | configplatformForApp(${PROJECT_NAME} ${ROOT} ${CORE} ${PLATFORMFOLDER}) |
| 37 | SET(PLATFORMID ${PLATFORMID} PARENT_SCOPE) |
| 38 | endfunction() |
| 39 | |
| 40 | function(configboot PROJECT_NAME ROOT PLATFORMFOLDER) |
| 41 | |
| 42 | target_include_directories(${PROJECT_NAME} PRIVATE ${ROOT}/CMSIS/DSP/Include) |
| 43 | set_platform_core() |
Christophe Favergeon | 26c2f68 | 2019-09-06 14:43:32 +0100 | [diff] [blame] | 44 | |
| 45 | if(EXPERIMENTAL) |
| 46 | experimentalConfigboot(${PROJECT_NAME} ${ROOT} ${PLATFORMFOLDER}) |
| 47 | if (ISCORTEXM) |
| 48 | cortexm(${CORE} ${PROJECT_NAME} ${ROOT} ${PLATFORMFOLDER} ${HASCSTARTUP}) |
| 49 | else() |
| 50 | cortexa(${CORE} ${PROJECT_NAME} ${ROOT} ${PLATFORMFOLDER}) |
| 51 | endif() |
| 52 | endif() |
Christophe Favergeon | 6b604eb | 2019-05-17 13:46:33 +0200 | [diff] [blame] | 53 | ################### |
| 54 | # |
Christophe Favergeon | c4c3480 | 2019-09-24 14:05:01 +0200 | [diff] [blame] | 55 | # Cortex M |
Christophe Favergeon | 6b604eb | 2019-05-17 13:46:33 +0200 | [diff] [blame] | 56 | # |
Christophe Favergeon | 512b148 | 2020-02-07 11:25:11 +0100 | [diff] [blame] | 57 | # C startup for M55 boot code |
Christophe Favergeon | 3f7bbfb | 2020-05-06 07:10:29 +0200 | [diff] [blame] | 58 | if (${PLATFORMID} STREQUAL "IPSS") |
Christophe Favergeon | 3f7bbfb | 2020-05-06 07:10:29 +0200 | [diff] [blame] | 59 | cortexm(${CORE} ${PROJECT_NAME} ${ROOT} ${PLATFORMFOLDER} ON) |
Christophe Favergeon | 3f7bbfb | 2020-05-06 07:10:29 +0200 | [diff] [blame] | 60 | else() |
| 61 | if (ARM_CPU MATCHES "^[cC]ortex-[mM]55([^0-9].*)?$") |
| 62 | cortexm(${CORE} ${PROJECT_NAME} ${ROOT} ${PLATFORMFOLDER} ON) |
| 63 | elseif (ARM_CPU MATCHES "^[cC]ortex-[Mm].*$") |
| 64 | cortexm(${CORE} ${PROJECT_NAME} ${ROOT} ${PLATFORMFOLDER} OFF) |
| 65 | endif() |
Christophe Favergeon | 6b604eb | 2019-05-17 13:46:33 +0200 | [diff] [blame] | 66 | endif() |
| 67 | |
Christophe Favergeon | 6b604eb | 2019-05-17 13:46:33 +0200 | [diff] [blame] | 68 | |
| 69 | ################### |
| 70 | # |
Christophe Favergeon | c67252c | 2020-06-18 11:11:51 +0200 | [diff] [blame^] | 71 | # Cortex cortex-a |
Christophe Favergeon | 6b604eb | 2019-05-17 13:46:33 +0200 | [diff] [blame] | 72 | # |
Christophe Favergeon | c4c3480 | 2019-09-24 14:05:01 +0200 | [diff] [blame] | 73 | if (ARM_CPU MATCHES "^[cC]ortex-[Aa].*") |
Christophe Favergeon | 3b2a0ee | 2019-06-12 13:29:14 +0200 | [diff] [blame] | 74 | cortexa(${CORE} ${PROJECT_NAME} ${ROOT} ${PLATFORMFOLDER}) |
| 75 | |
| 76 | endif() |
| 77 | |
| 78 | SET(PLATFORMID ${PLATFORMID} PARENT_SCOPE) |
| 79 | |
| 80 | endfunction() |
| 81 | |