/* * Copyright (c) 2020 Nordic Semiconductor ASA * * SPDX-License-Identifier: Apache-2.0 */ /* Periodic advertisements synchronization status. */ enum sync_status { SYNC_STAT_ALLOWED, SYNC_STAT_READY, SYNC_STAT_CONT_SCAN, SYNC_STAT_TERM }; struct lll_sync { struct lll_hdr hdr; uint8_t access_addr[4]; uint8_t crc_init[3]; uint8_t phy:3; /* Bitmask providing not allowed types of CTE. */ uint8_t cte_type:5; /* The member is required for filtering by CTE type. If filtering policy is disabled then * synchronization is terminated for periodic advertisements with wrong CTE type. */ uint8_t filter_policy:1; uint8_t is_rx_enabled:1; uint8_t is_aux_sched:1; uint8_t forced:1; #if defined(CONFIG_BT_CTLR_SYNC_ISO) || \ defined(CONFIG_BT_CTLR_SYNC_TRANSFER_RECEIVER) || \ defined(CONFIG_BT_CTLR_SYNC_TRANSFER_SENDER) uint8_t sca:3; #endif /* CONFIG_BT_CTLR_SYNC_ISO || CONFIG_BT_CTLR_SYNC_TRANSFER_RECEIVER/SENDER */ #if defined(CONFIG_BT_CTLR_SCAN_AUX_SYNC_RESERVE_MIN) /* Counter used by LLL abort of event when in unreserved time space to * provide near fair scheduling of overlapping multiple Periodic * Sync sets. */ uint8_t abort_count; #endif /* CONFIG_BT_CTLR_SCAN_AUX_SYNC_RESERVE_MIN */ uint16_t skip_prepare; uint16_t lazy_prepare; uint16_t skip_event; uint16_t event_counter; uint16_t data_chan_id; struct { uint8_t data_chan_map[PDU_CHANNEL_MAP_SIZE]; uint8_t data_chan_count:6; } chm[DOUBLE_BUFFER_SIZE]; uint8_t chm_first; uint8_t chm_last; uint16_t chm_instant; uint32_t window_widening_periodic_us; uint32_t window_widening_max_us; uint32_t window_widening_prepare_us; uint32_t window_widening_event_us; uint32_t window_size_event_us; /* used to store lll_aux when chain is being scanned */ struct lll_scan_aux *volatile lll_aux; #if defined(CONFIG_BT_CTLR_DF_SCAN_CTE_RX) struct lll_df_sync df_cfg; /* Member stores one additional IQ report rx node for notification of insufficient * resources to sample all CTEs in currently pending synchronization event. * The member is temporary storage used between prepare of an event and IQ data report * generation. */ struct node_rx_iq_report *node_cte_incomplete; /* Member stores information if there were insufficient IQ report rx nodes for all CTEs * in pending synchronization event. */ bool is_cte_incomplete; #endif /* CONFIG_BT_CTLR_DF_SCAN_CTE_RX */ }; int lll_sync_init(void); int lll_sync_reset(void); void lll_sync_create_prepare(void *param); void lll_sync_prepare(void *param); enum sync_status lll_sync_cte_is_allowed(uint8_t cte_type_mask, uint8_t filter_policy, uint8_t rx_cte_time, uint8_t rx_cte_type); extern uint16_t ull_sync_lll_handle_get(struct lll_sync *lll); extern struct lll_sync *ull_sync_lll_is_valid_get(struct lll_sync *lll);