blob: 56155066d10611033b3e81039cc50a30f970f8b0 [file] [log] [blame]
#----------------------------------------------------------------------------
# Copyright (c) 2022 Arm Limited. All rights reserved.
# SPDX-License-Identifier: Apache-2.0
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#----------------------------------------------------------------------------
#########################################################
# Generic CMSIS Start up library for Cortex-M targets #
#########################################################
cmake_minimum_required(VERSION 3.16.3)
set(CMSIS_DEVICE_TARGET cmsis_device)
set(CPU_HEADER_TARGET rte_components)
project(${CMSIS_DEVICE_TARGET}
DESCRIPTION "Generic CMSIS start up file for Cortex-M targets"
LANGUAGES C CXX ASM)
# 1. We should be cross-compiling (non-native target)
if (NOT ${CMAKE_CROSSCOMPILING})
message(FATAL_ERROR "No ${CMSIS_DEVICE_TARGET} support for this target.")
endif()
# 2. Check if CMSIS sources have been defined
if (NOT DEFINED CMSIS_SRC_PATH)
message(FATAL_ERROR "CMSIS_SRC_PATH path should be defined for ${CMSIS_DEVICE_TARGET}.")
endif()
# 3.1 Create an interface library for CPU header only
add_library(${CPU_HEADER_TARGET} INTERFACE)
## Interface include directories:
target_include_directories(${CPU_HEADER_TARGET}
INTERFACE
include
${CMSIS_SRC_PATH}/CMSIS/Core/Include
${CMSIS_SRC_PATH}/Device/ARM/${ARM_CPU}/Include
${CMSIS_SRC_PATH}/Device/ARM/${ARM_CPU}/Include/Template)
# 3.2 Create static library
add_library(${CMSIS_DEVICE_TARGET} STATIC)
## Sources - public
target_sources(${CMSIS_DEVICE_TARGET}
PUBLIC
source/handlers.c)
## Sources - private
target_sources(${CMSIS_DEVICE_TARGET}
PRIVATE
${CMSIS_SRC_PATH}/Device/ARM/${ARM_CPU}/Source/system_${ARM_CPU}.c
${CMSIS_SRC_PATH}/Device/ARM/${ARM_CPU}/Source/startup_${ARM_CPU}.c)
# Device definition needs to be set, is checked in source files to include correct header
target_compile_definitions(${CMSIS_DEVICE_TARGET} PUBLIC ${ARM_CPU})
# Tell linker that reset interrupt handler is our entry point
target_link_options(
${CMSIS_DEVICE_TARGET}
INTERFACE
--entry Reset_Handler)
# Link libraries
target_link_libraries(${CMSIS_DEVICE_TARGET}
PUBLIC
${CPU_HEADER_TARGET})
# Check if semihosting configuration is available
if (COMMAND configure_semihosting)
configure_semihosting(${CMSIS_DEVICE_TARGET} OFF)
endif()
# 4 Display status:
message(STATUS "CMAKE_CURRENT_SOURCE_DIR: " ${CMAKE_CURRENT_SOURCE_DIR})
message(STATUS "*******************************************************")
message(STATUS "Library : " ${CMSIS_DEVICE_TARGET})
message(STATUS "CMAKE_SYSTEM_PROCESSOR : " ${CMAKE_SYSTEM_PROCESSOR})
message(STATUS "CMAKE_SYSTEM_ARCH : " ${CMAKE_SYSTEM_ARCH})
message(STATUS "*******************************************************")