From cb8eb7e69eaaca409db0b901afd8f7cbee8b1ee3 Mon Sep 17 00:00:00 2001 From: "matthias.ringwald" Date: Mon, 20 Jun 2011 20:03:43 +0000 Subject: [PATCH] use L2CAP_STATE_WILL_SEND_DISCONNECT_REQUEST on client connection close --- src/l2cap.c | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/src/l2cap.c b/src/l2cap.c index 92247398f..298bd71a8 100644 --- a/src/l2cap.c +++ b/src/l2cap.c @@ -570,6 +570,8 @@ void l2cap_signaling_handler_channel(l2cap_channel_t *channel, uint8_t *command) case 0: // successful connection channel->remote_cid = READ_BT_16(command, L2CAP_SIGNALING_COMMAND_DATA_OFFSET); + + channel->sig_id = l2cap_next_sig_id(); config_options[0] = 1; // MTU config_options[1] = 2; // len param @@ -873,9 +875,7 @@ void l2cap_close_connection(void *connection){ for (it = (linked_item_t *) l2cap_channels; it ; it = it->next){ channel = (l2cap_channel_t *) it; if (channel->connection == connection) { - channel->sig_id = l2cap_next_sig_id(); - l2cap_send_signaling_packet( channel->handle, DISCONNECTION_REQUEST, channel->sig_id, channel->remote_cid, channel->local_cid); - channel->state = L2CAP_STATE_WAIT_DISCONNECT; + channel->state = L2CAP_STATE_WILL_SEND_DISCONNECT_REQUEST; } } @@ -890,5 +890,8 @@ void l2cap_close_connection(void *connection){ it = it->next; } } + + // process + l2cap_run(); } \ No newline at end of file