mirror of
https://github.com/zephyrproject-rtos/zephyr
synced 2025-09-08 15:02:42 +00:00
The bluetooth controller has been using the flag '-Ofast' to keep within a real-time limit. There are two problems with this; firstly, when a project should be optimized for size it is standard to use -O2, not -Ofast. Secondly, optimization flags have been deemed to be non-portable, so instead of directly using "-Ofast" we should use the intent-macro OPTIMIZE_FOR_SPEED_FLAG to ensure toolchain portability. Testing has shown that we are still within the real-time limit when changing from -Ofast to -O2. -Ofast is about 1us and 1% faster, but increases the code size by 13kB (5% of the available flash on a nRF51). Since the slowdown is comparatively small compared to the code size increase we have decided to use -O2 in place of -Ofast. Other optimization combinations were also measured and their results can be seen below: -Ofast in BLE Controller and in #pragma in entropy driver. Memory region Used Size Region Size %age Used FLASH: 138920 B 256 KB 52.99% [bt] [INF] encode_control: l: 6, 6, 7; t: 75, 45, 132. -O2 in BLE Controller and in #pragma in entropy driver. Memory region Used Size Region Size %age Used FLASH: 125840 B 256 KB 48.00% [bt] [INF] encode_control: l: 6, 6, 7; t: 75, 51, 133 -O3 in BLE Controller and in #pragma in entropy driver. Memory region Used Size Region Size %age Used FLASH: 138920 B 256 KB 52.99% [bt] [INF] encode_control: l: 6, 6, 7; t: 75, 50, 132. No extra CFLAGS for BLE and entropy driver (pragmas removed), using CONFIG_SIZE_OPTIMIZATIONS=y Memory region Used Size Region Size %age Used FLASH: 120124 B 256 KB 45.82% [bt] [ERR] isr_rx_conn: assert: '!radio_is_ready()' failed No extra CFLAGS for BLE and entropy driver (pragmas removed), using CONFIG_SPEED_OPTIMIZATIONS=y Memory region Used Size Region Size %age Used FLASH: 138004 B 256 KB 52.64% [bt] [INF] encode_control: l: 6, 6, 7; t: 61, 51, 130. NB: RAM usage differences were insignificant. Signed-off-by: Sebastian Bøe <sebastian.boe@nordicsemi.no>
69 lines
1.0 KiB
CMake
69 lines
1.0 KiB
CMake
zephyr_library()
|
|
zephyr_library_sources(
|
|
util/mem.c
|
|
util/memq.c
|
|
util/mayfly.c
|
|
util/util.c
|
|
ticker/ticker.c
|
|
ll_sw/ll_addr.c
|
|
ll_sw/ll_tx_pwr.c
|
|
ll_sw/ctrl.c
|
|
ll_sw/ll.c
|
|
hci/hci_driver.c
|
|
hci/hci.c
|
|
)
|
|
|
|
zephyr_library_sources_ifdef(
|
|
CONFIG_BT_CTLR_CRYPTO
|
|
crypto/crypto.c
|
|
)
|
|
|
|
zephyr_library_sources_ifdef(
|
|
CONFIG_BT_BROADCASTER
|
|
ll_sw/ll_adv.c
|
|
)
|
|
|
|
zephyr_library_sources_ifdef(
|
|
CONFIG_BT_OBSERVER
|
|
ll_sw/ll_scan.c
|
|
)
|
|
|
|
zephyr_library_sources_ifdef(
|
|
CONFIG_BT_CENTRAL
|
|
ll_sw/ll_master.c
|
|
)
|
|
|
|
zephyr_library_sources_ifdef(
|
|
CONFIG_BT_CTLR_DTM
|
|
ll_sw/ll_test.c
|
|
)
|
|
|
|
zephyr_library_sources_ifdef(
|
|
CONFIG_BT_CTLR_FILTER
|
|
ll_sw/ll_filter.c
|
|
)
|
|
|
|
zephyr_library_sources_ifdef(
|
|
CONFIG_SOC_COMPATIBLE_NRF
|
|
hal/nrf5/cntr.c
|
|
hal/nrf5/ecb.c
|
|
hal/nrf5/radio/radio.c
|
|
hal/nrf5/mayfly.c
|
|
hal/nrf5/ticker.c
|
|
)
|
|
|
|
zephyr_library_include_directories(
|
|
.
|
|
util
|
|
hal
|
|
ticker
|
|
include
|
|
)
|
|
|
|
zephyr_library_compile_options_ifdef(
|
|
CONFIG_BT_CTLR_FAST_ENC
|
|
${OPTIMIZE_FOR_SPEED_FLAG}
|
|
)
|
|
|
|
zephyr_library_link_libraries(subsys__bluetooth)
|