1 /* 2 * Copyright (c) 2020 Demant 3 * 4 * SPDX-License-Identifier: Apache-2.0 5 */ 6 7 /* Temporary data structure to avoid change ll_conn/lll_conn to much 8 * and having to update all the dependencies 9 */ 10 11 enum { ULL_CP_CONNECTED, ULL_CP_DISCONNECTED }; 12 13 /** 14 * @brief Initialize the LL Control Procedure system. 15 */ 16 void ull_cp_init(void); 17 18 /** 19 * @brief Initialize the LL Control Procedure connection data. 20 */ 21 void ull_llcp_init(struct ll_conn *conn); 22 23 /** 24 * @brief XXX 25 */ 26 void ull_cp_state_set(struct ll_conn *conn, uint8_t state); 27 28 void ull_cp_release_nodes(struct ll_conn *conn); 29 30 /* 31 * @brief Update 'global' tx buffer allowance 32 */ 33 void ull_cp_update_tx_buffer_queue(struct ll_conn *conn); 34 35 /** 36 * 37 */ 38 void ull_cp_release_tx(struct ll_conn *conn, struct node_tx *tx); 39 40 /** 41 * @brief Procedure Response Timeout Check 42 * @param elapsed_event The number of elapsed events. 43 * @param[out] error_code The error code for this timeout. 44 * @return 0 on success, -ETIMEDOUT if timer expired. 45 */ 46 int ull_cp_prt_elapse(struct ll_conn *conn, uint16_t elapsed_event, uint8_t *error_code); 47 48 void ull_cp_prt_reload_set(struct ll_conn *conn, uint32_t conn_intv); 49 50 /** 51 * @brief Run pending LL Control Procedures. 52 */ 53 void ull_cp_run(struct ll_conn *conn); 54 55 /** 56 * @brief Handle TX ack PDU. 57 */ 58 void ull_cp_tx_ack(struct ll_conn *conn, struct node_tx *tx); 59 60 /** 61 * @brief Handle TX procedures notifications towards Host. 62 */ 63 void ull_cp_tx_ntf(struct ll_conn *conn); 64 65 /** 66 * @brief Handle received LL Control PDU. 67 */ 68 void ull_cp_rx(struct ll_conn *conn, memq_link_t *link, struct node_rx_pdu *rx); 69 70 #if defined(CONFIG_BT_CTLR_LE_PING) 71 /** 72 * @brief Initiate a LE Ping Procedure. 73 */ 74 uint8_t ull_cp_le_ping(struct ll_conn *conn); 75 #endif /* CONFIG_BT_CTLR_LE_PING */ 76 77 /** 78 * @brief Initiate a Version Exchange Procedure. 79 */ 80 uint8_t ull_cp_version_exchange(struct ll_conn *conn); 81 82 /** 83 * @brief Initiate a Feature Exchange Procedure. 84 */ 85 uint8_t ull_cp_feature_exchange(struct ll_conn *conn, uint8_t host_initiated); 86 87 #if defined(CONFIG_BT_CTLR_MIN_USED_CHAN) 88 /** 89 * @brief Initiate a Minimum used channels Procedure. 90 */ 91 uint8_t ull_cp_min_used_chans(struct ll_conn *conn, uint8_t phys, uint8_t min_used_chans); 92 #endif /* CONFIG_BT_CTLR_MIN_USED_CHAN */ 93 94 /** 95 * @brief Initiate a Encryption Start Procedure. 96 */ 97 uint8_t ull_cp_encryption_start(struct ll_conn *conn, const uint8_t rand[8], const uint8_t ediv[2], 98 const uint8_t ltk[16]); 99 100 /** 101 * @brief Initiate a Encryption Pause Procedure. 102 */ 103 uint8_t ull_cp_encryption_pause(struct ll_conn *conn, const uint8_t rand[8], const uint8_t ediv[2], 104 const uint8_t ltk[16]); 105 106 /** 107 * @brief Check if an encryption pause procedure is active. 108 */ 109 uint8_t ull_cp_encryption_paused(struct ll_conn *conn); 110 111 /** 112 */ 113 uint8_t ull_cp_ltk_req_reply(struct ll_conn *conn, const uint8_t ltk[16]); 114 115 /** 116 */ 117 uint8_t ull_cp_ltk_req_neq_reply(struct ll_conn *conn); 118 119 /** 120 * @brief Initiate a PHY Update Procedure. 121 */ 122 uint8_t ull_cp_phy_update(struct ll_conn *conn, uint8_t tx, uint8_t flags, uint8_t rx, 123 uint8_t host_initiated); 124 125 /** 126 * @brief Initiate a Connection Parameter Request Procedure or Connection Update Procedure 127 */ 128 uint8_t ull_cp_conn_update(struct ll_conn *conn, uint16_t interval_min, uint16_t interval_max, 129 uint16_t latency, uint16_t timeout, uint16_t *offsets); 130 131 /** 132 * @brief Accept the remote device’s request to change connection parameters. 133 */ 134 void ull_cp_conn_param_req_reply(struct ll_conn *conn); 135 136 /** 137 * @brief Reject the remote device’s request to change connection parameters. 138 */ 139 void ull_cp_conn_param_req_neg_reply(struct ll_conn *conn, uint8_t error_code); 140 141 /** 142 * @brief Check if a remote data length update is in the works. 143 */ 144 uint8_t ull_cp_remote_dle_pending(struct ll_conn *conn); 145 146 /** 147 * @brief Check if a remote connection param reg is in the 148 * works. 149 */ 150 uint8_t ull_cp_remote_cpr_pending(struct ll_conn *conn); 151 152 /** 153 * @brief Check if a remote connection param reg is expecting an 154 * anchor point move response. 155 */ 156 bool ull_cp_remote_cpr_apm_awaiting_reply(struct ll_conn *conn); 157 158 /** 159 * @brief Respond to anchor point move of remote connection 160 * param reg. 161 */ 162 void ull_cp_remote_cpr_apm_reply(struct ll_conn *conn, uint16_t *offsets); 163 164 /** 165 * @brief Reject anchor point move of remote connection param 166 * reg. 167 */ 168 void ull_cp_remote_cpr_apm_neg_reply(struct ll_conn *conn, uint8_t error_code); 169 170 /** 171 * @brief Initiate a Termination Procedure. 172 */ 173 uint8_t ull_cp_terminate(struct ll_conn *conn, uint8_t error_code); 174 175 /** 176 * @brief Initiate a CIS Termination Procedure. 177 */ 178 uint8_t ull_cp_cis_terminate(struct ll_conn *conn, struct ll_conn_iso_stream *cis, 179 uint8_t error_code); 180 181 /** 182 * @brief Initiate a CIS Create Procedure. 183 */ 184 uint8_t ull_cp_cis_create(struct ll_conn *conn, struct ll_conn_iso_stream *cis); 185 186 /** 187 * @brief Resume CIS create after CIS offset calculation. 188 */ 189 void ull_cp_cc_offset_calc_reply(struct ll_conn *conn, uint32_t cis_offset_min, 190 uint32_t cis_offset_max); 191 192 /** 193 * @brief Is ongoing create cis procedure expecting a reply? 194 */ 195 bool ull_cp_cc_awaiting_reply(struct ll_conn *conn); 196 197 /** 198 * @brief Is ongoing create cis procedure expecting an established event? 199 */ 200 bool ull_cp_cc_awaiting_established(struct ll_conn *conn); 201 202 /** 203 * @brief Cancel ongoing create cis procedure 204 */ 205 bool ull_cp_cc_cancel(struct ll_conn *conn); 206 207 /** 208 * @brief Get handle of ongoing create cis procedure. 209 * @return 0xFFFF if none 210 */ 211 uint16_t ull_cp_cc_ongoing_handle(struct ll_conn *conn); 212 213 /** 214 * @brief Accept the remote device’s request to create cis. 215 */ 216 void ull_cp_cc_accept(struct ll_conn *conn, uint32_t cis_offset_min); 217 218 /** 219 * @brief Reject the remote device’s request to create cis. 220 */ 221 void ull_cp_cc_reject(struct ll_conn *conn, uint8_t error_code); 222 223 /** 224 * @brief CIS was established. 225 */ 226 void ull_cp_cc_established(struct ll_conn *conn, uint8_t error_code); 227 228 /** 229 * @brief CIS creation ongoing. 230 */ 231 bool ull_lp_cc_is_active(struct ll_conn *conn); 232 233 /** 234 * @brief CIS creation ongoing or enqueued. 235 */ 236 bool ull_lp_cc_is_enqueued(struct ll_conn *conn); 237 238 /** 239 * @brief Initiate a Channel Map Update Procedure. 240 */ 241 uint8_t ull_cp_chan_map_update(struct ll_conn *conn, const uint8_t chm[5]); 242 243 /** 244 * @brief Check if Channel Map Update Procedure is pending 245 */ 246 const uint8_t *ull_cp_chan_map_update_pending(struct ll_conn *conn); 247 248 #if defined(CONFIG_BT_CTLR_DATA_LENGTH) 249 /** 250 * @brief Initiate a Data Length Update Procedure. 251 */ 252 uint8_t ull_cp_data_length_update(struct ll_conn *conn, uint16_t max_tx_octets, 253 uint16_t max_tx_time); 254 #endif /* CONFIG_BT_CTLR_DATA_LENGTH */ 255 /** 256 * @brief Initiate a CTE Request Procedure. 257 */ 258 uint8_t ull_cp_cte_req(struct ll_conn *conn, uint8_t min_cte_len, uint8_t cte_type); 259 260 /** 261 * @brief Set a CTE Request Procedure disabled. 262 */ 263 void ull_cp_cte_req_set_disable(struct ll_conn *conn); 264 265 /** 266 * @brief Enable or disable response to CTE Request Procedure. 267 */ 268 void ull_cp_cte_rsp_enable(struct ll_conn *conn, bool enable, uint8_t max_cte_len, 269 uint8_t cte_types); 270 271 #if defined(CONFIG_BT_CTLR_SCA_UPDATE) 272 /** 273 * @brief Initiate a Sleep Clock Accuracy Update Procedure. 274 */ 275 uint8_t ull_cp_req_peer_sca(struct ll_conn *conn); 276 #endif /* CONFIG_BT_CTLR_SCA_UPDATE */ 277 278 #if defined(CONFIG_BT_CTLR_SYNC_TRANSFER_SENDER) 279 struct ll_adv_sync_set; 280 struct ll_sync_set; 281 282 /** 283 * @brief Initiate a Periodic Advertising Sync Transfer Procedure. 284 */ 285 uint8_t ull_cp_periodic_sync(struct ll_conn *conn, struct ll_sync_set *sync, 286 struct ll_adv_sync_set *adv_sync, uint16_t service_data); 287 288 void ull_lp_past_offset_get_calc_params(struct ll_conn *conn, 289 uint8_t *adv_sync_handle, uint16_t *sync_handle); 290 void ull_lp_past_offset_calc_reply(struct ll_conn *conn, uint32_t offset_us, 291 uint16_t pa_event_counter, uint16_t last_pa_event_counter); 292 void ull_lp_past_conn_evt_done(struct ll_conn *conn, struct node_rx_event_done *done); 293 #endif /* CONFIG_BT_CTLR_SYNC_TRANSFER_SENDER */ 294 295 /** 296 * @brief Validation of PHY, checking if exactly one bit set, and no bit set is rfu's 297 */ 298 bool phy_valid(uint8_t phy); 299