1 /* 2 * Copyright (c) 2018-2019 Nordic Semiconductor ASA 3 * 4 * SPDX-License-Identifier: Apache-2.0 5 */ 6 7 #define EVENT_OVERHEAD_XTAL_US 1500 8 #define EVENT_OVERHEAD_PREEMPT_US 0 /* if <= min, then dynamic preempt */ 9 #define EVENT_OVERHEAD_PREEMPT_MIN_US 0 10 #define EVENT_OVERHEAD_PREEMPT_MAX_US EVENT_OVERHEAD_XTAL_US 11 12 /* Measurement based on drifting roles that can overlap leading to collision 13 * resolutions that consume CPU time between radio events. 14 * Value include max end, start and scheduling CPU usage times. 15 * Measurements based on central_gatt_write and peripheral_gatt_write sample on 16 * nRF52833 SoC. 17 */ 18 #if defined(CONFIG_BT_CTLR_ADV_EXT) 19 #if defined(CONFIG_BT_OBSERVER) 20 #if defined(CONFIG_BT_CTLR_PHY_CODED) 21 /* Active connection in peripheral role with extended scanning on 1M and Coded 22 * PHY, scheduling and receiving auxiliary PDUs. 23 */ 24 #define EVENT_OVERHEAD_START_US 733 /* 24 RTC ticks */ 25 #else /* !CONFIG_BT_CTLR_PHY_CODED */ 26 /* Active connection in peripheral role with extended scanning on 1M only, 27 * scheduling and receiving auxiliary PDUs. 28 */ 29 #define EVENT_OVERHEAD_START_US 428 /* 14 RTC ticks */ 30 #endif /* !CONFIG_BT_CTLR_PHY_CODED */ 31 #else /* !CONFIG_BT_OBSERVER */ 32 /* Active connection in peripheral role with legacy scanning on 1M. 33 */ 34 #define EVENT_OVERHEAD_START_US 275 /* 9 RTC ticks */ 35 #endif /* !CONFIG_BT_OBSERVER */ 36 #else /* !CONFIG_BT_CTLR_ADV_EXT */ 37 /* Active connection in peripheral role with additional advertising state. 38 */ 39 #define EVENT_OVERHEAD_START_US 275 /* 9 RTC ticks */ 40 #endif /* !CONFIG_BT_CTLR_ADV_EXT */ 41 42 /* Worst-case time margin needed after event end-time in the air 43 * (done/preempt race margin + power-down/chain delay) 44 */ 45 #define EVENT_OVERHEAD_END_US 40 46 47 /* Sleep Clock Accuracy */ 48 #define EVENT_JITTER_US 16 49 50 /* Inter-Event Space (IES) */ 51 #define EVENT_TIES_US 625 52 53 /* Ticker resolution margin 54 * Needed due to the lack of fine timing resolution in ticker_start 55 * and ticker_update. Set to 32 us, which is ~1 tick with 32768 Hz 56 * clock. 57 */ 58 #define EVENT_TICKER_RES_MARGIN_US DIV_ROUND_UP(HAL_TICKER_CNTR_CLK_UNIT_FSEC, \ 59 HAL_TICKER_FSEC_PER_USEC) 60 61 #define EVENT_RX_JITTER_US(phy) 16 /* Radio Rx timing uncertainty */ 62 #define EVENT_RX_TO_US(phy) ((((((phy)&0x03) + 4)<<3)/BIT((((phy)&0x3)>>1))) + \ 63 EVENT_RX_JITTER_US(phy)) 64 65 /* Turnaround time between RX and TX is based on CPU execution speed. It also 66 * includes radio ramp up time. The value must meet hard deadline of `150 us` 67 * imposed by BT Core spec for inter frame spacing (IFS). To include CPUs with 68 * slow clock, the conservative approach was taken to use IFS value for all 69 * cases. 70 */ 71 #define EVENT_RX_TX_TURNAROUND(phy) 150 72 73 /* Sub-microsecond conversion macros. With current timer resolution of ~30 us 74 * per tick, conversion factor is 1, and macros map 1:1 between us_frac and us. 75 * On sub-microsecond tick resolution architectures, a number of bits may be 76 * used to represent fractions of a microsecond, to allow higher precision in 77 * window widening. 78 */ 79 #define EVENT_US_TO_US_FRAC(us) (us) 80 #define EVENT_US_FRAC_TO_US(us_frac) (us_frac) 81 #define EVENT_TICKS_TO_US_FRAC(ticks) HAL_TICKER_TICKS_TO_US(ticks) 82 #define EVENT_US_FRAC_TO_TICKS(us_frac) HAL_TICKER_US_TO_TICKS(us_frac) 83 #define EVENT_US_FRAC_TO_REMAINDER(us_frac) HAL_TICKER_REMAINDER(us_frac) 84 85 /* Time needed to set up a CIS from ACL instant to prepare (incl. radio). Used 86 * for CIS_Offset_Min. 87 */ 88 #define EVENT_OVERHEAD_CIS_SETUP_US MAX(EVENT_OVERHEAD_START_US, 500U) 89