mirror of
https://github.com/bluekitchen/btstack.git
synced 2025-01-26 12:35:25 +00:00
treat L2CAP CONNECTION_RESPONSE with result = pending as error, just wait
This commit is contained in:
parent
aeccc34dce
commit
38e5900eda
34
src/l2cap.c
34
src/l2cap.c
@ -171,27 +171,37 @@ void l2cap_signaling_handler(l2cap_channel_t *channel, uint8_t *packet, uint16_t
|
|||||||
|
|
||||||
static uint8_t config_options[] = { 1, 2, 150, 0}; // mtu = 48
|
static uint8_t config_options[] = { 1, 2, 150, 0}; // mtu = 48
|
||||||
|
|
||||||
uint8_t code = READ_L2CAP_SIGNALING_CODE( packet );
|
uint8_t code = READ_L2CAP_SIGNALING_CODE( packet );
|
||||||
uint8_t identifier = READ_L2CAP_SIGNALING_IDENTIFIER( packet );
|
uint8_t identifier = READ_L2CAP_SIGNALING_IDENTIFIER( packet );
|
||||||
|
uint16_t result = 0;
|
||||||
|
|
||||||
switch (channel->state) {
|
switch (channel->state) {
|
||||||
|
|
||||||
case L2CAP_STATE_WAIT_CONNECT_RSP:
|
case L2CAP_STATE_WAIT_CONNECT_RSP:
|
||||||
switch (code){
|
switch (code){
|
||||||
case CONNECTION_RESPONSE:
|
case CONNECTION_RESPONSE:
|
||||||
if ( READ_BT_16 (packet, L2CAP_SIGNALING_DATA_OFFSET+3) == 0){
|
result = READ_BT_16 (packet, L2CAP_SIGNALING_DATA_OFFSET+3);
|
||||||
// successfull connection
|
switch (result) {
|
||||||
channel->dest_cid = READ_BT_16(packet, L2CAP_SIGNALING_DATA_OFFSET + 0);
|
case 0:
|
||||||
channel->sig_id = l2cap_next_sig_id();
|
// successfull connection
|
||||||
l2cap_send_signaling_packet(channel->handle, CONFIGURE_REQUEST, channel->sig_id, channel->dest_cid, 0, 4, &config_options);
|
channel->dest_cid = READ_BT_16(packet, L2CAP_SIGNALING_DATA_OFFSET + 0);
|
||||||
channel->state = L2CAP_STATE_WAIT_CONFIG_REQ_RSP;
|
channel->sig_id = l2cap_next_sig_id();
|
||||||
} else {
|
l2cap_send_signaling_packet(channel->handle, CONFIGURE_REQUEST, channel->sig_id, channel->dest_cid, 0, 4, &config_options);
|
||||||
// map l2cap connection response result to BTstack status enumeration
|
channel->state = L2CAP_STATE_WAIT_CONFIG_REQ_RSP;
|
||||||
l2cap_emit_channel_opened(channel, L2CAP_CONNECTION_RESPONSE_RESULT_SUCCESSFUL
|
break;
|
||||||
+ READ_BT_16 (packet, L2CAP_SIGNALING_DATA_OFFSET+3));
|
case 1:
|
||||||
|
// connection pending. get some coffee
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
// map l2cap connection response result to BTstack status enumeration
|
||||||
|
l2cap_emit_channel_opened(channel, L2CAP_CONNECTION_RESPONSE_RESULT_SUCCESSFUL + result);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
//@TODO: implement other signaling packets
|
//@TODO: implement other signaling packets
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user