From 155c06b83fc3e88574c10000cc8a8045f079a900 Mon Sep 17 00:00:00 2001 From: Kristian Lauszus Date: Wed, 3 Oct 2012 20:14:01 +0200 Subject: [PATCH] Clear flags after reading them --- SPP.cpp | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/SPP.cpp b/SPP.cpp index 74631ad0..3b1e95e7 100644 --- a/SPP.cpp +++ b/SPP.cpp @@ -379,6 +379,7 @@ void SPP::SDP_task() { { case L2CAP_SDP_WAIT: if (l2cap_connection_request_sdp_flag) { + l2cap_event_flag &= ~L2CAP_FLAG_CONNECTION_SDP_REQUEST; // Clear flag #ifdef DEBUG Notify(PSTR("\r\nSDP Incoming Connection Request")); #endif @@ -393,6 +394,7 @@ void SPP::SDP_task() { break; case L2CAP_SDP_REQUEST: if (l2cap_config_request_sdp_flag) { + l2cap_event_flag &= ~L2CAP_FLAG_CONFIG_SDP_REQUEST; // Clear flag #ifdef DEBUG Notify(PSTR("\r\nSDP Configuration Request")); #endif @@ -402,6 +404,7 @@ void SPP::SDP_task() { break; case L2CAP_SDP_SUCCESS: if (l2cap_config_success_sdp_flag) { + l2cap_event_flag &= ~L2CAP_FLAG_CONFIG_SDP_SUCCESS; // Clear flag #ifdef DEBUG Notify(PSTR("\r\nSDP Successfully Configured")); #endif @@ -412,12 +415,12 @@ void SPP::SDP_task() { break; case L2CAP_SDP_DONE: if(l2cap_disconnect_request_sdp_flag) { + l2cap_event_flag &= ~L2CAP_FLAG_DISCONNECT_SDP_REQUEST; // Clear flag SDPConnected = false; #ifdef DEBUG Notify(PSTR("\r\nDisconnected SDP Channel")); #endif - pBtd->l2cap_disconnection_response(hci_handle,identifier,sdp_dcid,sdp_scid); - l2cap_event_flag = 0; // Reset flags + pBtd->l2cap_disconnection_response(hci_handle,identifier,sdp_dcid,sdp_scid); l2cap_sdp_state = L2CAP_SDP_WAIT; } break; @@ -442,6 +445,7 @@ void SPP::RFCOMM_task() { case L2CAP_RFCOMM_WAIT: if(l2cap_connection_request_rfcomm_flag) { + l2cap_event_flag &= ~L2CAP_FLAG_CONNECTION_RFCOMM_REQUEST; // Clear flag #ifdef DEBUG Notify(PSTR("\r\nRFCOMM Incoming Connection Request")); #endif @@ -456,6 +460,7 @@ void SPP::RFCOMM_task() break; case L2CAP_RFCOMM_REQUEST: if (l2cap_config_request_rfcomm_flag) { + l2cap_event_flag &= ~L2CAP_FLAG_CONFIG_RFCOMM_REQUEST; // Clear flag #ifdef DEBUG Notify(PSTR("\r\nRFCOMM Configuration Request")); #endif @@ -465,6 +470,7 @@ void SPP::RFCOMM_task() break; case L2CAP_RFCOMM_SUCCESS: if (l2cap_config_success_rfcomm_flag) { + l2cap_event_flag &= ~L2CAP_FLAG_CONFIG_RFCOMM_SUCCESS; // Clear flag #ifdef DEBUG Notify(PSTR("\r\nRFCOMM Successfully Configured")); #endif @@ -476,13 +482,13 @@ void SPP::RFCOMM_task() break; case L2CAP_RFCOMM_DONE: if(l2cap_disconnect_request_rfcomm_flag) { + l2cap_event_flag &= ~L2CAP_FLAG_DISCONNECT_RFCOMM_REQUEST; // Clear flag RFCOMMConnected = false; connected = false; #ifdef DEBUG Notify(PSTR("\r\nDisconnected RFCOMM Channel")); #endif pBtd->l2cap_disconnection_response(hci_handle,identifier,rfcomm_dcid,rfcomm_scid); - l2cap_event_flag = 0; // Reset flags l2cap_rfcomm_state = L2CAP_RFCOMM_WAIT; } break;