mirror of
https://github.com/bluekitchen/btstack.git
synced 2025-01-03 23:47:08 +00:00
daemon: request for can send now if sending L2CAP/RFCOMM packet fails due to flow control
This commit is contained in:
parent
45756c9055
commit
10a9d10518
@ -1360,10 +1360,34 @@ static int daemon_client_handler(connection_t *connection, uint16_t packet_type,
|
|||||||
case L2CAP_DATA_PACKET:
|
case L2CAP_DATA_PACKET:
|
||||||
// process l2cap packet...
|
// process l2cap packet...
|
||||||
err = l2cap_send(channel, data, length);
|
err = l2cap_send(channel, data, length);
|
||||||
|
switch (err){
|
||||||
|
case BTSTACK_ACL_BUFFERS_FULL:
|
||||||
|
// temp flow issue
|
||||||
|
l2cap_request_can_send_now_event(channel);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
// sending failed
|
||||||
|
err = ERROR_CODE_SUCCESS;
|
||||||
|
log_error("Dropping L2CAP packet");
|
||||||
|
break;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case RFCOMM_DATA_PACKET:
|
case RFCOMM_DATA_PACKET:
|
||||||
// process rfcomm packet...
|
// process rfcomm packet...
|
||||||
err = rfcomm_send(channel, data, length);
|
err = rfcomm_send(channel, data, length);
|
||||||
|
switch (err){
|
||||||
|
case BTSTACK_ACL_BUFFERS_FULL:
|
||||||
|
case RFCOMM_NO_OUTGOING_CREDITS:
|
||||||
|
case RFCOMM_AGGREGATE_FLOW_OFF:
|
||||||
|
// flow issue
|
||||||
|
rfcomm_request_can_send_now_event(channel);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
// sending failed
|
||||||
|
err = ERROR_CODE_SUCCESS;
|
||||||
|
log_error("Dropping RFCOMM packet");
|
||||||
|
break;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case DAEMON_EVENT_PACKET:
|
case DAEMON_EVENT_PACKET:
|
||||||
switch (data[0]) {
|
switch (data[0]) {
|
||||||
@ -1600,6 +1624,9 @@ static void daemon_packet_handler(void * connection, uint8_t packet_type, uint16
|
|||||||
daemon_add_client_rfcomm_channel(connection, cid);
|
daemon_add_client_rfcomm_channel(connection, cid);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case RFCOMM_EVENT_CAN_SEND_NOW:
|
||||||
|
daemon_retry_parked();
|
||||||
|
break;
|
||||||
case RFCOMM_EVENT_CHANNEL_CLOSED:
|
case RFCOMM_EVENT_CHANNEL_CLOSED:
|
||||||
cid = little_endian_read_16(packet, 2);
|
cid = little_endian_read_16(packet, 2);
|
||||||
connection = connection_for_rfcomm_cid(cid);
|
connection = connection_for_rfcomm_cid(cid);
|
||||||
@ -1620,6 +1647,9 @@ static void daemon_packet_handler(void * connection, uint8_t packet_type, uint16
|
|||||||
daemon_add_client_l2cap_channel(connection, cid);
|
daemon_add_client_l2cap_channel(connection, cid);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case L2CAP_EVENT_CAN_SEND_NOW:
|
||||||
|
daemon_retry_parked();
|
||||||
|
break;
|
||||||
case L2CAP_EVENT_CHANNEL_CLOSED:
|
case L2CAP_EVENT_CHANNEL_CLOSED:
|
||||||
cid = little_endian_read_16(packet, 2);
|
cid = little_endian_read_16(packet, 2);
|
||||||
connection = connection_for_l2cap_cid(cid);
|
connection = connection_for_l2cap_cid(cid);
|
||||||
|
Loading…
Reference in New Issue
Block a user