uint32_t sd_ble_gap_sec_info_reply(adapter_t *adapter, uint16_t conn_handle, ble_gap_enc_info_t const *p_enc_info, ble_gap_irk_t const *p_id_info, ble_gap_sign_info_t const *p_sign_info) { encode_function_t encode_function = [&](uint8_t *buffer, uint32_t *length) -> uint32_t { return ble_gap_sec_info_reply_req_enc(conn_handle, p_enc_info, p_id_info, p_sign_info, buffer, length); }; decode_function_t decode_function = [&](uint8_t *buffer, uint32_t length, uint32_t *result) -> uint32_t { return ble_gap_sec_info_reply_rsp_dec(buffer, length, result); }; return gap_encode_decode(adapter, encode_function, decode_function); }
uint32_t sd_ble_gap_sec_info_reply(uint16_t conn_handle, ble_gap_enc_info_t const * p_enc_info, ble_gap_irk_t const * p_id_info, ble_gap_sign_info_t const * p_sign_info) { uint8_t * p_buffer; uint32_t buffer_length = 0; tx_buf_alloc(&p_buffer, (uint16_t *)&buffer_length); const uint32_t err_code = ble_gap_sec_info_reply_req_enc(conn_handle, p_enc_info, p_id_info, p_sign_info, &(p_buffer[1]), &buffer_length); APP_ERROR_CHECK(err_code); //@note: Increment buffer length as internally managed packet type field must be included. return ser_sd_transport_cmd_write(p_buffer, (++buffer_length), gap_sec_info_reply_rsp_dec); }