#!!! TODO stuff in this pre-amble will be defined by the target description, #hard-coding for now... set(MBED_LEGACY_TARGET_DEFINITIONS "NORDIC" "NRF51822_MKIT" "MCU_NRF51822" "MCU_NORDIC_16K") set(MBED_LEGACY_TOOLCHAIN "GCC_ARM") add_definitions("-DNRF51") set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -std=gnu99") # # mbed-2 yotta-compatible build system # # make sure necessary features are enabled: project(mbed) enable_language(ASM) # 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_ name, recurse only if 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}") # 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 ${MBED_COMMON_SOURCES} ${MBED_TARGET_SOURCES} )