mirror of https://github.com/ARMmbed/mbed-os.git
Merge pull request #1213 from autopulated/yotta-build
Make it possible to build the core mbed library with yottapull/1220/head
commit
ae2d3cdffe
|
@ -0,0 +1,112 @@
|
|||
#
|
||||
# mbed-2 yotta-compatible build system
|
||||
#
|
||||
|
||||
# make sure necessary features are enabled:
|
||||
project(mbed-classic)
|
||||
enable_language(ASM)
|
||||
|
||||
# override compilation flags:
|
||||
if(CMAKE_C_COMPILER_ID MATCHES GNU)
|
||||
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -std=gnu99")
|
||||
endif()
|
||||
|
||||
# the mbed.a library is built from two sets of source files + include
|
||||
# directories:
|
||||
#
|
||||
# MBED_COMMON_SOURCES: the source files that are the same for all targets,
|
||||
# these are easily found by globbing:
|
||||
#
|
||||
file(GLOB MBED_COMMON_SOURCES "common/*.cpp" "common/*.c")
|
||||
#
|
||||
# (always include the hal header directory, too)
|
||||
set(MBED_COMMON_INCLUDE_DIRS "hal")
|
||||
|
||||
# and MBED_TARGET_SOURCES: these depend on which target we are building for. To
|
||||
# find these we need to walk the directories in targets/, and wherever we see a
|
||||
# TARGET_<something> name, recurse only if <something> matches what we're
|
||||
# currently building for
|
||||
macro(mbed_find_target_dirs PARENT_DIRECTORY SOURCES_LIST INCLUDES_LIST)
|
||||
# append this directory to the search path:
|
||||
list(APPEND ${INCLUDES_LIST} "${PARENT_DIRECTORY}")
|
||||
# add all source files in this directory to the sources list:
|
||||
file(GLOB sources "${PARENT_DIRECTORY}/*.cpp" "${PARENT_DIRECTORY}/*.c" "${PARENT_DIRECTORY}/*.s" "${PARENT_DIRECTORY}/*.S" )
|
||||
list(APPEND ${SOURCES_LIST} ${sources})
|
||||
|
||||
# get a list of all subdirectories that we want to recurse into:
|
||||
file(GLOB dir_children RELATIVE "${PARENT_DIRECTORY}" "${PARENT_DIRECTORY}/*")
|
||||
set(matching_subdirs "")
|
||||
foreach(child ${dir_children})
|
||||
if(IS_DIRECTORY "${PARENT_DIRECTORY}/${child}")
|
||||
# is this directory name a magic one?
|
||||
if("${child}" MATCHES "^TARGET_")
|
||||
# target-magic: recurse if the MBED_LEGACY_TARGET_DEFINITIONS **list**
|
||||
# contains a matching value:
|
||||
foreach(legacy_magic_def ${MBED_LEGACY_TARGET_DEFINITIONS})
|
||||
# we could probably unroll the list into a single regex if
|
||||
# this is a performance problem:
|
||||
if("${child}" MATCHES "^TARGET_${legacy_magic_def}$")
|
||||
list(APPEND matching_subdirs ${child})
|
||||
break()
|
||||
endif()
|
||||
endforeach()
|
||||
elseif("${child}" MATCHES "^TOOLCHAIN_")
|
||||
# toolchain-magic: (recurse if the MBED_LEGACY_TOOLCHAIN matches
|
||||
# this name)
|
||||
if("${child}" MATCHES "^TOOLCHAIN_${MBED_LEGACY_TOOLCHAIN}$")
|
||||
list(APPEND matching_subdirs "${child}")
|
||||
endif()
|
||||
else()
|
||||
# not special: always recurse into this directory
|
||||
list(APPEND matching_subdirs "${child}")
|
||||
endif()
|
||||
endif()
|
||||
endforeach()
|
||||
#message("matching_subdirs: ${matching_subdirs}")
|
||||
|
||||
# recurse:
|
||||
foreach(subdir ${matching_subdirs})
|
||||
mbed_find_target_dirs("${PARENT_DIRECTORY}/${subdir}" ${SOURCES_LIST} ${INCLUDES_LIST})
|
||||
endforeach()
|
||||
endmacro()
|
||||
|
||||
set(MBED_TARGET_SOURCES "")
|
||||
set(MBED_TARGET_INCLUDE_DIRS "")
|
||||
mbed_find_target_dirs("${CMAKE_CURRENT_SOURCE_DIR}/targets" MBED_TARGET_SOURCES MBED_TARGET_INCLUDE_DIRS)
|
||||
#message("found target sources: ${MBED_TARGET_SOURCES}")
|
||||
#message("found target include dirs: ${MBED_TARGET_INCLUDE_DIRS}")
|
||||
|
||||
# unfortunately, for ARMCC, the startup code needs to be provided as an object
|
||||
# on the command line (not as part of an archive). To do this we override the
|
||||
# CMake add_executable command.
|
||||
if(CMAKE_C_COMPILER_ID STREQUAL "ARMCC")
|
||||
set(MBED_TARGET_STARTUP_CODE_SOURCES "")
|
||||
foreach(src ${MBED_TARGET_SOURCES})
|
||||
if("${src}" MATCHES .*startup_.*\\.[sS])
|
||||
LIST(APPEND MBED_TARGET_STARTUP_CODE_SOURCES "${src}")
|
||||
endif()
|
||||
endforeach()
|
||||
add_library(mbed_classic_startupcod OBJECT ${MBED_TARGET_STARTUP_CODE_SOURCES})
|
||||
macro (add_executable _name)
|
||||
_add_executable(${ARGV} $<TARGET_OBJECTS:mbed_classic_startupcod>)
|
||||
endmacro()
|
||||
endif()
|
||||
|
||||
# we have to append any target-specific include dirs to the global include dirs
|
||||
# list, so that any indirect includes (e.g. via mbed.h) of files in those
|
||||
# directories will work:
|
||||
# (non-target-specific include dirs are listed in extraIncludes in module.json)
|
||||
foreach(dir ${MBED_TARGET_INCLUDE_DIRS})
|
||||
set_property(GLOBAL APPEND PROPERTY YOTTA_GLOBAL_INCLUDE_DIRS ${dir})
|
||||
endforeach()
|
||||
|
||||
# finally, we can construct a library using the determined set of include paths
|
||||
# + source files. Note that the library name must match the name of the yotta
|
||||
# module (defined in module.json) for this module to link properly with other
|
||||
# yotta modules.
|
||||
include_directories(${MBED_COMMON_INCLUDE_DIRS})
|
||||
include_directories(${MBED_TARGET_INCLUDE_DIRS})
|
||||
add_library(mbed-classic
|
||||
${MBED_COMMON_SOURCES}
|
||||
${MBED_TARGET_SOURCES}
|
||||
)
|
|
@ -0,0 +1,30 @@
|
|||
{
|
||||
"name": "mbed-classic",
|
||||
"version": "0.0.1",
|
||||
"description": "mbed core SDK (for mbed 2.0, *not* mbedOS)",
|
||||
"keywords": [
|
||||
"mbed"
|
||||
],
|
||||
"author": "Bogdan Marinescu <bogdan.marinescu@arm.com>",
|
||||
"repository": {
|
||||
"url": "git@github.com:mbedmicro/mbed.git",
|
||||
"type": "git"
|
||||
},
|
||||
"homepage": "https://github.com/mbedmicro/mbed",
|
||||
"licenses": [
|
||||
{
|
||||
"url": "https://spdx.org/licenses/Apache-2.0",
|
||||
"type": "Apache-2.0"
|
||||
}
|
||||
],
|
||||
"extraIncludes": [
|
||||
"api",
|
||||
"hal",
|
||||
"targets/hal",
|
||||
"targets/cmsis"
|
||||
],
|
||||
"dependencies": {
|
||||
},
|
||||
"targetDependencies": {
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue