1f9739491SMatthias Ringwald #include <stdint.h> 2f9739491SMatthias Ringwald #include <stdio.h> 3f9739491SMatthias Ringwald #include <stdlib.h> 4f9739491SMatthias Ringwald #include <string.h> 5f9739491SMatthias Ringwald 6f9739491SMatthias Ringwald #include "hci.h" 7e0ff5d41SMatthias Ringwald #include "gap.h" 8f9739491SMatthias Ringwald #include "hci_dump.h" 9f9739491SMatthias Ringwald #include "l2cap.h" 10f9739491SMatthias Ringwald 11f9739491SMatthias Ringwald #include "ble/att_db.h" 121b37bf00SMilanka Ringwald #include "ble/att_dispatch.h" 13f9739491SMatthias Ringwald #include "ble/sm.h" 14f9739491SMatthias Ringwald 15ae970bb9SMilanka Ringwald #include "btstack_debug.h" 16ae970bb9SMilanka Ringwald 171b37bf00SMilanka Ringwald static btstack_packet_handler_t att_server_packet_handler; 18f9739491SMatthias Ringwald static void (*registered_hci_event_handler) (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size) = NULL; 19f9739491SMatthias Ringwald 20f9739491SMatthias Ringwald static btstack_linked_list_t connections; 218206902cSMilanka Ringwald static uint16_t max_mtu = 23; 228206902cSMilanka Ringwald static uint8_t l2cap_stack_buffer[HCI_INCOMING_PRE_BUFFER_SIZE + 8 + ATT_DEFAULT_MTU]; // pre buffer + HCI Header + L2CAP header 23f9739491SMatthias Ringwald static uint16_t gatt_client_handle = 0x40; 24f9739491SMatthias Ringwald static hci_connection_t hci_connection; 25f9739491SMatthias Ringwald 26f9739491SMatthias Ringwald uint16_t get_gatt_client_handle(void){ 27f9739491SMatthias Ringwald return gatt_client_handle; 28f9739491SMatthias Ringwald } 29f9739491SMatthias Ringwald 30f9739491SMatthias Ringwald void mock_simulate_command_complete(const hci_cmd_t *cmd){ 31f9739491SMatthias Ringwald uint8_t packet[] = {HCI_EVENT_COMMAND_COMPLETE, 4, 1, (uint8_t) (cmd->opcode & 0xff), (uint8_t) (cmd->opcode >> 8), 0}; 32f9739491SMatthias Ringwald registered_hci_event_handler(HCI_EVENT_PACKET, 0, (uint8_t *)&packet, sizeof(packet)); 33f9739491SMatthias Ringwald } 34f9739491SMatthias Ringwald 35f9739491SMatthias Ringwald void mock_simulate_hci_state_working(void){ 36f9739491SMatthias Ringwald uint8_t packet[3] = {BTSTACK_EVENT_STATE, 0, HCI_STATE_WORKING}; 37f9739491SMatthias Ringwald registered_hci_event_handler(HCI_EVENT_PACKET, 0, (uint8_t *)&packet, 3); 38f9739491SMatthias Ringwald } 39f9739491SMatthias Ringwald 40*38e85ba1SMatthias Ringwald static void hci_create_gap_connection_complete_event(const uint8_t * hci_event, uint8_t * gap_event) { 41*38e85ba1SMatthias Ringwald gap_event[0] = HCI_EVENT_META_GAP; 42*38e85ba1SMatthias Ringwald gap_event[1] = 36 - 2; 43*38e85ba1SMatthias Ringwald gap_event[2] = GAP_SUBEVENT_LE_CONNECTION_COMPLETE; 44*38e85ba1SMatthias Ringwald switch (hci_event[2]){ 45*38e85ba1SMatthias Ringwald case HCI_SUBEVENT_LE_CONNECTION_COMPLETE: 46*38e85ba1SMatthias Ringwald memcpy(&gap_event[3], &hci_event[3], 11); 47*38e85ba1SMatthias Ringwald memset(&gap_event[14], 0, 12); 48*38e85ba1SMatthias Ringwald memcpy(&gap_event[26], &hci_event[14], 7); 49*38e85ba1SMatthias Ringwald memset(&gap_event[33], 0xff, 3); 50*38e85ba1SMatthias Ringwald break; 51*38e85ba1SMatthias Ringwald case HCI_SUBEVENT_LE_ENHANCED_CONNECTION_COMPLETE_V1: 52*38e85ba1SMatthias Ringwald memcpy(&gap_event[3], &hci_event[3], 30); 53*38e85ba1SMatthias Ringwald memset(&gap_event[33], 0xff, 3); 54*38e85ba1SMatthias Ringwald break; 55*38e85ba1SMatthias Ringwald case HCI_SUBEVENT_LE_ENHANCED_CONNECTION_COMPLETE_V2: 56*38e85ba1SMatthias Ringwald memcpy(&gap_event[3], &hci_event[3], 33); 57*38e85ba1SMatthias Ringwald break; 58*38e85ba1SMatthias Ringwald default: 59*38e85ba1SMatthias Ringwald btstack_unreachable(); 60*38e85ba1SMatthias Ringwald break; 61*38e85ba1SMatthias Ringwald } 62*38e85ba1SMatthias Ringwald } 63*38e85ba1SMatthias Ringwald 64f9739491SMatthias Ringwald void mock_simulate_connected(void){ 65f9739491SMatthias Ringwald uint8_t packet[] = {0x3E, 0x13, 0x01, 0x00, 0x40, 0x00, 0x00, 0x00, 0x9B, 0x77, 0xD1, 0xF7, 0xB1, 0x34, 0x50, 0x00, 0x00, 0x00, 0xD0, 0x07, 0x05}; 66*38e85ba1SMatthias Ringwald uint8_t gap_event[36]; 67*38e85ba1SMatthias Ringwald hci_create_gap_connection_complete_event(packet, gap_event); 68*38e85ba1SMatthias Ringwald registered_hci_event_handler(HCI_EVENT_PACKET, 0, gap_event, sizeof(gap_event)); 69f9739491SMatthias Ringwald } 70f9739491SMatthias Ringwald 71f9739491SMatthias Ringwald void mock_simulate_scan_response(void){ 72f9739491SMatthias Ringwald uint8_t packet[] = {0xE2, 0x13, 0xE2, 0x01, 0x34, 0xB1, 0xF7, 0xD1, 0x77, 0x9B, 0xCC, 0x09, 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08}; 73f9739491SMatthias Ringwald registered_hci_event_handler(HCI_EVENT_PACKET, 0, (uint8_t *)&packet, sizeof(packet)); 74f9739491SMatthias Ringwald } 75f9739491SMatthias Ringwald 76f9739491SMatthias Ringwald void gap_start_scan(void){ 77f9739491SMatthias Ringwald } 78f9739491SMatthias Ringwald void gap_stop_scan(void){ 79f9739491SMatthias Ringwald } 80e0ff5d41SMatthias Ringwald uint8_t gap_connect(const bd_addr_t addr, bd_addr_type_t addr_type){ 81f9739491SMatthias Ringwald return 0; 82f9739491SMatthias Ringwald } 83f9739491SMatthias Ringwald void gap_set_scan_parameters(uint8_t scan_type, uint16_t scan_interval, uint16_t scan_window){ 84f9739491SMatthias Ringwald } 85f9739491SMatthias Ringwald 86f9739491SMatthias Ringwald int gap_reconnect_security_setup_active(hci_con_handle_t con_handle){ 87f9739491SMatthias Ringwald UNUSED(con_handle); 88f9739491SMatthias Ringwald return 0; 89f9739491SMatthias Ringwald } 90f9739491SMatthias Ringwald 91effffa37SMilanka Ringwald static void hci_setup_connection(uint16_t con_handle, bd_addr_type_t type){ 9225336c94SMilanka Ringwald hci_connection.att_connection.mtu = 23; 9325336c94SMilanka Ringwald hci_connection.att_connection.con_handle = con_handle; 9425336c94SMilanka Ringwald hci_connection.att_connection.max_mtu = 23; 9525336c94SMilanka Ringwald hci_connection.att_connection.encryption_key_size = 0; 9625336c94SMilanka Ringwald hci_connection.att_connection.authenticated = 0; 9725336c94SMilanka Ringwald hci_connection.att_connection.authorized = 0; 9825336c94SMilanka Ringwald 9925336c94SMilanka Ringwald hci_connection.att_server.ir_le_device_db_index = 0; 10025336c94SMilanka Ringwald 1018206902cSMilanka Ringwald hci_connection.con_handle = con_handle; 102effffa37SMilanka Ringwald hci_connection.address_type = type; 1038206902cSMilanka Ringwald 10425336c94SMilanka Ringwald if (btstack_linked_list_empty(&connections)){ 10525336c94SMilanka Ringwald btstack_linked_list_add(&connections, (btstack_linked_item_t *)&hci_connection); 10625336c94SMilanka Ringwald } 107f9739491SMatthias Ringwald } 108f9739491SMatthias Ringwald 109effffa37SMilanka Ringwald void hci_setup_le_connection(uint16_t con_handle){ 110effffa37SMilanka Ringwald hci_setup_connection(con_handle, BD_ADDR_TYPE_LE_PUBLIC); 111effffa37SMilanka Ringwald } 112effffa37SMilanka Ringwald 113effffa37SMilanka Ringwald void hci_setup_classic_connection(uint16_t con_handle){ 114effffa37SMilanka Ringwald hci_setup_connection(con_handle, BD_ADDR_TYPE_ACL); 115effffa37SMilanka Ringwald } 116effffa37SMilanka Ringwald 117effffa37SMilanka Ringwald 1188206902cSMilanka Ringwald void mock_l2cap_set_max_mtu(uint16_t mtu){ 1198206902cSMilanka Ringwald max_mtu = mtu; 1201a47f80bSMatthias Ringwald } 1211a47f80bSMatthias Ringwald 1228206902cSMilanka Ringwald void hci_deinit(void){ 1238206902cSMilanka Ringwald hci_connection.att_connection.mtu = 0; 1248206902cSMilanka Ringwald hci_connection.att_connection.con_handle = HCI_CON_HANDLE_INVALID; 1258206902cSMilanka Ringwald hci_connection.att_connection.max_mtu = 0; 1268206902cSMilanka Ringwald hci_connection.att_connection.encryption_key_size = 0; 1278206902cSMilanka Ringwald hci_connection.att_connection.authenticated = 0; 1288206902cSMilanka Ringwald hci_connection.att_connection.authorized = 0; 1298206902cSMilanka Ringwald hci_connection.att_server.ir_le_device_db_index = 0; 1308206902cSMilanka Ringwald hci_connection.att_server.notification_requests = NULL; 1318206902cSMilanka Ringwald hci_connection.att_server.indication_requests = NULL; 1328206902cSMilanka Ringwald connections = NULL; 1338206902cSMilanka Ringwald } 1348206902cSMilanka Ringwald 1358206902cSMilanka Ringwald void hci_add_event_handler(btstack_packet_callback_registration_t * callback_handler){ 1368206902cSMilanka Ringwald registered_hci_event_handler = callback_handler->callback; 137f9739491SMatthias Ringwald } 138f9739491SMatthias Ringwald 13977fc16acSMatthias Ringwald bool hci_can_send_command_packet_now(void){ 14077fc16acSMatthias Ringwald return true; 141ae970bb9SMilanka Ringwald } 142ae970bb9SMilanka Ringwald 143ae970bb9SMilanka Ringwald HCI_STATE hci_get_state(void){ 144ae970bb9SMilanka Ringwald return HCI_STATE_WORKING; 145ae970bb9SMilanka Ringwald } 146ae970bb9SMilanka Ringwald 14777fc16acSMatthias Ringwald uint8_t hci_send_cmd(const hci_cmd_t *cmd, ...){ 148ae970bb9SMilanka Ringwald btstack_assert(false); 14977fc16acSMatthias Ringwald return ERROR_CODE_SUCCESS; 150ae970bb9SMilanka Ringwald } 151ae970bb9SMilanka Ringwald 152ae970bb9SMilanka Ringwald void hci_halting_defer(void){ 153ae970bb9SMilanka Ringwald } 154ae970bb9SMilanka Ringwald 15577fc16acSMatthias Ringwald bool l2cap_can_send_connectionless_packet_now(void){ 156f9739491SMatthias Ringwald return 1; 157f9739491SMatthias Ringwald } 158f9739491SMatthias Ringwald 1591a47f80bSMatthias Ringwald void l2cap_add_event_handler(btstack_packet_callback_registration_t * callback_handler){ 1601a47f80bSMatthias Ringwald UNUSED(callback_handler); 1611a47f80bSMatthias Ringwald } 1621a47f80bSMatthias Ringwald 163f9739491SMatthias Ringwald uint8_t *l2cap_get_outgoing_buffer(void){ 164f9739491SMatthias Ringwald // printf("l2cap_get_outgoing_buffer\n"); 165f9739491SMatthias Ringwald return (uint8_t *)&l2cap_stack_buffer; // 8 bytes 166f9739491SMatthias Ringwald } 167f9739491SMatthias Ringwald 168f9739491SMatthias Ringwald uint16_t l2cap_max_mtu(void){ 169f9739491SMatthias Ringwald // printf("l2cap_max_mtu\n"); 170f9739491SMatthias Ringwald return max_mtu; 171f9739491SMatthias Ringwald } 172f9739491SMatthias Ringwald 173f9739491SMatthias Ringwald uint16_t l2cap_max_le_mtu(void){ 174f9739491SMatthias Ringwald return max_mtu; 175f9739491SMatthias Ringwald } 176f9739491SMatthias Ringwald 177f9739491SMatthias Ringwald void l2cap_init(void){} 178f9739491SMatthias Ringwald 17977fc16acSMatthias Ringwald bool l2cap_reserve_packet_buffer(void){ 18077fc16acSMatthias Ringwald return true; 181f9739491SMatthias Ringwald } 182f9739491SMatthias Ringwald 183f9739491SMatthias Ringwald void l2cap_release_packet_buffer(void){ 184f9739491SMatthias Ringwald } 185f9739491SMatthias Ringwald 186782c1ae9SMilanka Ringwald static uint8_t l2cap_can_send_fixed_channel_packet_now_status = 1; 187782c1ae9SMilanka Ringwald 188782c1ae9SMilanka Ringwald void l2cap_can_send_fixed_channel_packet_now_set_status(uint8_t status){ 189782c1ae9SMilanka Ringwald l2cap_can_send_fixed_channel_packet_now_status = status; 190782c1ae9SMilanka Ringwald } 191782c1ae9SMilanka Ringwald 19277fc16acSMatthias Ringwald bool l2cap_can_send_fixed_channel_packet_now(uint16_t handle, uint16_t channel_id){ 193782c1ae9SMilanka Ringwald return l2cap_can_send_fixed_channel_packet_now_status; 194f9739491SMatthias Ringwald } 195f9739491SMatthias Ringwald 196f9739491SMatthias Ringwald void l2cap_request_can_send_fix_channel_now_event(uint16_t handle, uint16_t channel_id){ 197f9739491SMatthias Ringwald uint8_t event[] = { L2CAP_EVENT_CAN_SEND_NOW, 2, 1, 0}; 1981b37bf00SMilanka Ringwald att_server_packet_handler(HCI_EVENT_PACKET, 0, (uint8_t*)event, sizeof(event)); 199f9739491SMatthias Ringwald } 200f9739491SMatthias Ringwald 20177fc16acSMatthias Ringwald uint8_t l2cap_send_prepared_connectionless(uint16_t handle, uint16_t cid, uint16_t len){ 202f9739491SMatthias Ringwald att_connection_t att_connection; 2038206902cSMilanka Ringwald hci_setup_le_connection(handle); 204f9739491SMatthias Ringwald uint8_t response[max_mtu]; 205f9739491SMatthias Ringwald uint16_t response_len = att_handle_request(&att_connection, l2cap_get_outgoing_buffer(), len, &response[0]); 206f9739491SMatthias Ringwald if (response_len){ 2071b37bf00SMilanka Ringwald att_server_packet_handler(ATT_DATA_PACKET, gatt_client_handle, &response[0], response_len); 208f9739491SMatthias Ringwald } 20977fc16acSMatthias Ringwald return ERROR_CODE_SUCCESS; 210f9739491SMatthias Ringwald } 211f9739491SMatthias Ringwald 212c673a243SMilanka Ringwald static int cmac_ready = 1; 213c673a243SMilanka Ringwald void set_cmac_ready(int ready){ 214c673a243SMilanka Ringwald cmac_ready = ready; 215c673a243SMilanka Ringwald } 216c673a243SMilanka Ringwald 217f9739491SMatthias Ringwald void sm_add_event_handler(btstack_packet_callback_registration_t * callback_handler){ 218f9739491SMatthias Ringwald } 219f9739491SMatthias Ringwald 220f9739491SMatthias Ringwald int sm_cmac_ready(void){ 221c673a243SMilanka Ringwald return cmac_ready; 222f9739491SMatthias Ringwald } 223c673a243SMilanka Ringwald 224f9739491SMatthias Ringwald void sm_cmac_signed_write_start(const sm_key_t key, uint8_t opcode, uint16_t attribute_handle, uint16_t message_len, const uint8_t * message, uint32_t sign_counter, void (*done_callback)(uint8_t * hash)){ 225f9739491SMatthias Ringwald // sm_notify_client(SM_EVENT_IDENTITY_RESOLVING_SUCCEEDED, sm_central_device_addr_type, sm_central_device_address, 0, sm_central_device_matched); 226f9739491SMatthias Ringwald } 227c673a243SMilanka Ringwald 228f9739491SMatthias Ringwald int sm_le_device_index(uint16_t handle ){ 229f9739491SMatthias Ringwald return -1; 230f9739491SMatthias Ringwald } 231f9739491SMatthias Ringwald 232f9739491SMatthias Ringwald irk_lookup_state_t sm_identity_resolving_state(hci_con_handle_t con_handle){ 233f9739491SMatthias Ringwald return IRK_LOOKUP_SUCCEEDED; 234f9739491SMatthias Ringwald } 235f9739491SMatthias Ringwald 236f9739491SMatthias Ringwald void sm_request_pairing(hci_con_handle_t con_handle){ 237f9739491SMatthias Ringwald } 238f9739491SMatthias Ringwald 239f9739491SMatthias Ringwald void btstack_run_loop_set_timer(btstack_timer_source_t *a, uint32_t timeout_in_ms){ 240f9739491SMatthias Ringwald } 241f9739491SMatthias Ringwald 242f9739491SMatthias Ringwald // Set callback that will be executed when timer expires. 243f9739491SMatthias Ringwald void btstack_run_loop_set_timer_handler(btstack_timer_source_t *ts, void (*process)(btstack_timer_source_t *_ts)){ 244f9739491SMatthias Ringwald } 245f9739491SMatthias Ringwald 246f9739491SMatthias Ringwald // Add/Remove timer source. 247f9739491SMatthias Ringwald void btstack_run_loop_add_timer(btstack_timer_source_t *timer){ 248f9739491SMatthias Ringwald } 249f9739491SMatthias Ringwald 250f9739491SMatthias Ringwald int btstack_run_loop_remove_timer(btstack_timer_source_t *timer){ 251f9739491SMatthias Ringwald return 1; 252f9739491SMatthias Ringwald } 253f9739491SMatthias Ringwald 254f9739491SMatthias Ringwald void * btstack_run_loop_get_timer_context(btstack_timer_source_t *ts){ 255f9739491SMatthias Ringwald return ts->context; 256f9739491SMatthias Ringwald } 257f9739491SMatthias Ringwald 258f9739491SMatthias Ringwald // todo: 259e0ff5d41SMatthias Ringwald hci_connection_t * hci_connection_for_bd_addr_and_type(const bd_addr_t addr, bd_addr_type_t addr_type){ 260f9739491SMatthias Ringwald printf("hci_connection_for_bd_addr_and_type not implemented in mock backend\n"); 261f9739491SMatthias Ringwald return NULL; 262f9739491SMatthias Ringwald } 263f9739491SMatthias Ringwald hci_connection_t * hci_connection_for_handle(hci_con_handle_t con_handle){ 2648206902cSMilanka Ringwald if (hci_connection.con_handle != con_handle){ 2658206902cSMilanka Ringwald return NULL; 2668206902cSMilanka Ringwald } 267f9739491SMatthias Ringwald return &hci_connection; 268f9739491SMatthias Ringwald } 2698206902cSMilanka Ringwald 270f9739491SMatthias Ringwald void hci_connections_get_iterator(btstack_linked_list_iterator_t *it){ 271f9739491SMatthias Ringwald // printf("hci_connections_get_iterator not implemented in mock backend\n"); 272f9739491SMatthias Ringwald btstack_linked_list_iterator_init(it, &connections); 273f9739491SMatthias Ringwald } 274f9739491SMatthias Ringwald 275f9739491SMatthias Ringwald 276f9739491SMatthias Ringwald void l2cap_run(void){ 277f9739491SMatthias Ringwald } 278f9739491SMatthias Ringwald 2791a449638SMatthias Ringwald void l2cap_register_packet_handler(void (*handler)(uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size)){ 2801a449638SMatthias Ringwald } 2811a449638SMatthias Ringwald 2822e7076acSMatthias Ringwald bool gap_authenticated(hci_con_handle_t con_handle){ 2832e7076acSMatthias Ringwald return false; 284f9739491SMatthias Ringwald } 285f9739491SMatthias Ringwald authorization_state_t gap_authorization_state(hci_con_handle_t con_handle){ 286f9739491SMatthias Ringwald return AUTHORIZATION_UNKNOWN; 287f9739491SMatthias Ringwald } 2882e7076acSMatthias Ringwald uint8_t gap_encryption_key_size(hci_con_handle_t con_handle){ 289f9739491SMatthias Ringwald return 0; 290f9739491SMatthias Ringwald } 2912e7076acSMatthias Ringwald bool gap_secure_connection(hci_con_handle_t con_handle){ 2922e7076acSMatthias Ringwald return false; 293f9739491SMatthias Ringwald } 29418cd0f45SMilanka Ringwald gap_connection_type_t gap_get_connection_type(hci_con_handle_t con_handle){ 29518cd0f45SMilanka Ringwald if (hci_connection.con_handle != con_handle){ 296f9739491SMatthias Ringwald return GAP_CONNECTION_INVALID; 297f9739491SMatthias Ringwald } 29818cd0f45SMilanka Ringwald switch (hci_connection.address_type){ 29918cd0f45SMilanka Ringwald case BD_ADDR_TYPE_LE_PUBLIC: 30018cd0f45SMilanka Ringwald case BD_ADDR_TYPE_LE_RANDOM: 30118cd0f45SMilanka Ringwald return GAP_CONNECTION_LE; 30218cd0f45SMilanka Ringwald case BD_ADDR_TYPE_SCO: 30318cd0f45SMilanka Ringwald return GAP_CONNECTION_SCO; 30418cd0f45SMilanka Ringwald case BD_ADDR_TYPE_ACL: 30518cd0f45SMilanka Ringwald return GAP_CONNECTION_ACL; 30618cd0f45SMilanka Ringwald default: 30718cd0f45SMilanka Ringwald return GAP_CONNECTION_INVALID; 30818cd0f45SMilanka Ringwald } 30918cd0f45SMilanka Ringwald } 31018cd0f45SMilanka Ringwald 3111a449638SMatthias Ringwald int gap_request_connection_parameter_update(hci_con_handle_t con_handle, uint16_t conn_interval_min, 3121a449638SMatthias Ringwald uint16_t conn_interval_max, uint16_t conn_latency, uint16_t supervision_timeout){ 3131a449638SMatthias Ringwald return 0; 3141a449638SMatthias Ringwald } 3151b37bf00SMilanka Ringwald 3161b37bf00SMilanka Ringwald void mock_call_att_server_packet_handler(uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){ 3171b37bf00SMilanka Ringwald (*att_server_packet_handler)(packet_type, channel, packet, size); 3181b37bf00SMilanka Ringwald } 3191b37bf00SMilanka Ringwald 3208206902cSMilanka Ringwald void mock_call_att_packet_handler(uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){ 3218206902cSMilanka Ringwald (*registered_hci_event_handler)(packet_type, channel, packet, size); 3228206902cSMilanka Ringwald } 3238206902cSMilanka Ringwald 3241b37bf00SMilanka Ringwald void att_dispatch_register_server(btstack_packet_handler_t packet_handler){ 3251b37bf00SMilanka Ringwald att_server_packet_handler = packet_handler; 3261b37bf00SMilanka Ringwald } 3271b37bf00SMilanka Ringwald 3284a7a258fSMatthias Ringwald bool att_dispatch_server_can_send_now(hci_con_handle_t con_handle){ 3291b37bf00SMilanka Ringwald UNUSED(con_handle); 3301b37bf00SMilanka Ringwald return l2cap_can_send_fixed_channel_packet_now_status; 3311b37bf00SMilanka Ringwald } 3321b37bf00SMilanka Ringwald 3331b37bf00SMilanka Ringwald void att_dispatch_server_mtu_exchanged(hci_con_handle_t con_handle, uint16_t new_mtu){ 3341b37bf00SMilanka Ringwald UNUSED(con_handle); 3351b37bf00SMilanka Ringwald UNUSED(new_mtu); 3361b37bf00SMilanka Ringwald } 3371b37bf00SMilanka Ringwald 3381b37bf00SMilanka Ringwald void att_dispatch_server_request_can_send_now_event(hci_con_handle_t con_handle){ 33994c4ec6bSMilanka Ringwald if (l2cap_can_send_fixed_channel_packet_now_status){ 34025336c94SMilanka Ringwald uint8_t event[] = { L2CAP_EVENT_CAN_SEND_NOW, 2, 1, 0}; 34125336c94SMilanka Ringwald att_server_packet_handler(HCI_EVENT_PACKET, 0, (uint8_t*)event, sizeof(event)); 3421b37bf00SMilanka Ringwald } 34394c4ec6bSMilanka Ringwald } 3448206902cSMilanka Ringwald 345