aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTrygve Laugstøl <trygvis@inamo.no>2016-11-12 13:02:30 +0100
committerTrygve Laugstøl <trygvis@inamo.no>2016-11-12 13:02:30 +0100
commitd6e6c587e9f5c599bae57a9a5532c6f9a108906a (patch)
tree65d08435451e0a09291ef71ff340f97121a3321a
parentb31c8738e284119baa625aeef8ab6e6ede620756 (diff)
downloadmcu.cmake-d6e6c587e9f5c599bae57a9a5532c6f9a108906a.tar.gz
mcu.cmake-d6e6c587e9f5c599bae57a9a5532c6f9a108906a.tar.bz2
mcu.cmake-d6e6c587e9f5c599bae57a9a5532c6f9a108906a.tar.xz
mcu.cmake-d6e6c587e9f5c599bae57a9a5532c6f9a108906a.zip
o Support for S132.
-rw-r--r--nrf5x.cmake4
-rw-r--r--nrf5x/utils.cmake27
2 files changed, 30 insertions, 1 deletions
diff --git a/nrf5x.cmake b/nrf5x.cmake
index 2f37500..38333af 100644
--- a/nrf5x.cmake
+++ b/nrf5x.cmake
@@ -74,3 +74,7 @@ include(CMakeFindBinUtils)
set(CMAKE_C_COMPILER ${ARM_CC} CACHE FILE "")
set(CMAKE_CXX_COMPILER ${ARM_CXX} CACHE FILE "")
set(CMAKE_TRY_COMPILE_TARGET_TYPE STATIC_LIBRARY)
+
+# The ARM compilers today support this.
+set(CMAKE_C_STANDARD 11)
+set(CMAKE_CXX_STANDARD 14)
diff --git a/nrf5x/utils.cmake b/nrf5x/utils.cmake
index 97e2ddc..a583659 100644
--- a/nrf5x/utils.cmake
+++ b/nrf5x/utils.cmake
@@ -27,6 +27,9 @@ function(mcu_add_executable)
endif ()
if (ARGS_LINKER_SCRIPT)
+ if(NOT IS_ABSOLUTE "${ARGS_LINKER_SCRIPT}")
+ set(ARGS_LINKER_SCRIPT "${CMAKE_CURRENT_SOURCE_DIR}/${ARGS_LINKER_SCRIPT}")
+ endif()
set_target_properties(${ARGS_TARGET} PROPERTIES MCU_LINKER_SCRIPT "${ARGS_LINKER_SCRIPT}")
endif ()
@@ -51,12 +54,24 @@ function(mcu_add_executable)
target_link_libraries(${ARGS_TARGET} PRIVATE -Wl,-Map=${ARGS_TARGET}.map)
# -Wall -Werror -O3 -g3
+ # "-ffunction-sections"
+ # "-fdata-sections"
+ # "-fno-strict-aliasing"
+ # "-fno-builtin"
+ # "--short-enums"
+
if (${MCU_CHIP} MATCHES "nrf51.*")
target_compile_options(${ARGS_TARGET} PUBLIC
"-mcpu=cortex-m0"
"-mthumb"
"-mabi=aapcs"
"-mfloat-abi=soft")
+ target_link_libraries(${ARGS_TARGET} PRIVATE
+ "-mcpu=cortex-m0"
+ "-mthumb"
+ "-mabi=aapcs"
+ "-Wl,--gc-sections"
+ )
elseif (${MCU_CHIP} MATCHES "nrf52.*")
target_compile_options(${ARGS_TARGET} PUBLIC
"-mcpu=cortex-m4"
@@ -218,7 +233,17 @@ function(_nrf_softdevice_includes SOFTDEVICE INCLUDES_VAR DEFINES_VAR)
list(APPEND includes ${MCU_NRF5X_SDK_PATH}/components/softdevice/s${SOFTDEVICE}/headers/nrf52)
endif ()
- list(APPEND defines S${SOFTDEVICE} SOFTDEVICE_PRESENT)
+ list(APPEND defines
+ S${SOFTDEVICE}
+ SOFTDEVICE_PRESENT
+ BLE_STACK_SUPPORT_REQD)
+
+ set(NRF_SD_BLE_API_VERSION 2)
+ if (${SOFTDEVICE} MATCHES "132")
+ set(NRF_SD_BLE_API_VERSION 3)
+ endif ()
+ list(APPEND defines NRF_SD_BLE_API_VERSION=${NRF_SD_BLE_API_VERSION})
+
else ()
list(APPEND includes ${MCU_NRF5X_SDK_PATH}/components/drivers_nrf/nrf_soc_nosd)
endif ()