1 /******************************************************************
3 * Copyright 2014 Samsung Electronics All Rights Reserved.
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
19 ******************************************************************/
24 * This file contains the APIs for EDR adapter.
27 #include "caedradapter.h"
29 #include "caedrinterface.h"
30 #include "caadapterutils.h"
32 #include "caqueueingthread.h"
33 #include "oic_malloc.h"
34 #include "caremotehandler.h"
37 * @var EDR_ADAPTER_TAG
38 * @brief Logging tag for module name.
40 #define EDR_ADAPTER_TAG "CA_EDR_ADAPTER"
43 * @var g_edrThreadPool
44 * @brief Reference to threadpool.
46 static ca_thread_pool_t g_edrThreadPool = NULL;
49 * @var g_sendQueueHandle
50 * @brief Queue handle for Send Data
52 static CAQueueingThread_t *g_sendQueueHandle = NULL;
55 * @var g_recvQueueHandle
56 * @brief Queue handle for Receive Data
58 static CAQueueingThread_t *g_recvQueueHandle = NULL;
62 * @brief Storing Adapter state information
64 static bool g_adapterState = true;
67 * @var g_networkPacketReceivedCallback
68 * @brief Maintains the callback to be notified on receival of network packets from other
71 static CANetworkPacketReceivedCallback g_networkPacketReceivedCallback = NULL;
74 * @var g_networkChangeCallback
75 * @brief Maintains the callback to be notified on local bluetooth adapter status change.
77 static CANetworkChangeCallback g_networkChangeCallback = NULL;
80 * @var g_errorCallback
81 * @brief error Callback to CA adapter
83 static CAErrorHandleCallback g_errorCallback = NULL;
86 * @var g_localConnectivity
87 * @brief Information of local Bluetooth adapter.
89 static CAEndpoint_t *g_localConnectivity = NULL;
93 * @brief Storing Rfcommserver state information
95 static bool g_serverState = false;
97 static CAResult_t CAStartServer();
98 static CAResult_t CAEDRInitializeQueueHandlers();
99 CAResult_t CAEDRInitializeSendHandler();
100 CAResult_t CAEDRInitializeReceiveHandler();
101 void CAAdapterTerminateQueues();
102 void CAAdapterDataSendHandler(void *context);
103 void CAAdapterDataReceiverHandler(void *context);
104 CAResult_t CAAdapterStopQueue();
105 void CAAdapterRecvData(const char *remoteAddress, const uint8_t *data, uint32_t dataLength,
106 uint32_t *sentLength);
107 void CAEDRNotifyNetworkStatus(CANetworkStatus_t status);
108 void CAEDROnNetworkStatusChanged(void *context);
109 CAResult_t CAAdapterSendData(const char *remoteAddress, const char *serviceUUID, const uint8_t *data,
110 uint32_t dataLength, uint32_t *sentLength);
111 CAEDRNetworkEvent *CAEDRCreateNetworkEvent(CAEndpoint_t *connectivity,
112 CANetworkStatus_t status);
114 CAResult_t CAEDRClientSendData(const char *remoteAddress,
116 uint32_t dataLength);
119 * @fn CACreateEDRData
120 * @brief Helper function to create CAEDRData
122 static CAEDRData *CACreateEDRData(const CAEndpoint_t *remoteEndpoint, const uint8_t *data,
123 uint32_t dataLength);
127 * @brief Free the Created EDR data
129 static void CAFreeEDRData(CAEDRData *edrData);
132 * @fn CAEDRFreeNetworkEvent
133 * @brief Free the memory associated with @event.
135 void CAEDRFreeNetworkEvent(CAEDRNetworkEvent *event);
137 static void CAEDRDataDestroyer(void *data, uint32_t size);
139 static void CAEDRErrorHandler(const char *remoteAddress, const uint8_t *data,
140 uint32_t dataLength, CAResult_t result);
142 CAResult_t CAInitializeEDR(CARegisterConnectivityCallback registerCallback,
143 CANetworkPacketReceivedCallback packetReceivedCallback,
144 CANetworkChangeCallback networkStateChangeCallback,
145 CAErrorHandleCallback errorCallback, ca_thread_pool_t handle)
147 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
150 VERIFY_NON_NULL(registerCallback, EDR_ADAPTER_TAG, "register callback is NULL");
151 VERIFY_NON_NULL(packetReceivedCallback, EDR_ADAPTER_TAG, "data receive callback is NULL");
152 VERIFY_NON_NULL(networkStateChangeCallback, EDR_ADAPTER_TAG,
153 "network state change callback is NULL");
154 VERIFY_NON_NULL(handle, EDR_ADAPTER_TAG, "Thread pool handle is NULL");
156 // Register the callbacks
158 g_edrThreadPool = handle;
159 g_networkPacketReceivedCallback = packetReceivedCallback;
160 g_networkChangeCallback = networkStateChangeCallback;
161 g_errorCallback = errorCallback;
163 // Initialize EDR Network Monitor
164 CAResult_t err = CAEDRInitializeNetworkMonitor(handle);
165 if (CA_STATUS_OK != err)
167 OIC_LOG_V(ERROR, EDR_ADAPTER_TAG, "EDR N/w Monitor Initialize failed!, error number [%d]",
172 CAEDRSetNetworkChangeCallback(CAEDRNotifyNetworkStatus);
173 CAEDRSetPacketReceivedCallback(CAAdapterRecvData);
174 CAEDRSetErrorHandler(CAEDRErrorHandler);
175 CAEDRInitializeClient(handle);
177 CAConnectivityHandler_t handler;
178 handler.startAdapter = CAStartEDR;
179 handler.startListenServer = CAStartEDRListeningServer;
180 handler.startDiscoveryServer = CAStartEDRDiscoveryServer;
181 handler.sendData = CASendEDRUnicastData;
182 handler.sendDataToAll = CASendEDRMulticastData;
183 handler.GetnetInfo = CAGetEDRInterfaceInformation;
184 handler.readData = CAReadEDRData;
185 handler.stopAdapter = CAStopEDR;
186 handler.terminate = CATerminateEDR;
187 registerCallback(handler, CA_ADAPTER_RFCOMM_BTEDR);
189 // Initialize Send/Receive data message queues
190 if (CA_STATUS_OK != CAEDRInitializeQueueHandlers())
192 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "CAAdapterInitializeQueues API failed");
194 return CA_STATUS_FAILED;
197 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT");
201 CAResult_t CAStartEDR()
203 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
205 //Start Monitoring EDR Network
206 CAResult_t ret = CAEDRStartNetworkMonitor();
207 if (CA_STATUS_OK != ret)
209 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Failed to Start n/w monitor");
212 // Get Bluetooth adapter state
213 bool adapterState = false;
214 if (CA_STATUS_OK != CAEDRGetAdapterEnableState(&adapterState))
216 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Failed to get adapter enable state");
217 return CA_STATUS_FAILED;
220 if (false == adapterState)
222 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Bluetooth adapter is disabled!");
223 g_adapterState = false;
224 return CA_ADAPTER_NOT_ENABLED;
227 if (CA_STATUS_OK != (ret = CAEDRClientSetCallbacks()))
229 OIC_LOG_V(ERROR, EDR_ADAPTER_TAG, "Start Network Monitor failed!, error number [%d] ",
233 if (CA_STATUS_OK != (ret = CAAdapterStartQueue()))
235 OIC_LOG_V(ERROR, EDR_ADAPTER_TAG, "CAAdapterStartQueue failed!, error number [%d] ", ret);
238 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT");
242 CAResult_t CAStartEDRListeningServer()
244 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
246 return CAStartServer();
249 CAResult_t CAStartEDRDiscoveryServer()
251 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
253 return CAStartServer();
256 int32_t CASendEDRUnicastData(const CAEndpoint_t *remoteEndpoint, const void *data,
259 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
262 VERIFY_NON_NULL_RET(remoteEndpoint, EDR_ADAPTER_TAG, "Remote endpoint is null", -1);
263 VERIFY_NON_NULL_RET(data, EDR_ADAPTER_TAG, "Data is null", -1);
267 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Invalid input: data length is zero!");
271 if (0 == strlen(remoteEndpoint->addr))
273 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Invalid input: EDR Address is empty!");
277 uint32_t sentLength = 0;
278 const char *serviceUUID = OIC_EDR_SERVICE_ID;
279 const char *address = remoteEndpoint->addr;
280 CAResult_t err = CAAdapterSendData(address, serviceUUID, data, dataLength, &sentLength);
281 if (CA_STATUS_OK != err)
283 OIC_LOG_V(ERROR, EDR_ADAPTER_TAG, "Send unicast data failed!, error num [%d]", err);
284 g_errorCallback(remoteEndpoint, data, dataLength, err);
288 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT");
292 int32_t CASendEDRMulticastData(const CAEndpoint_t *endpoint, const void *data, uint32_t dataLength)
294 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN - CASendEDRMulticastData");
297 VERIFY_NON_NULL_RET(data, EDR_ADAPTER_TAG, "Data is null", -1);
301 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Invalid input: data length is zero!");
305 uint32_t sentLen = 0;
306 const char *serviceUUID = OIC_EDR_SERVICE_ID;
307 CAResult_t err = CAAdapterSendData(NULL, serviceUUID, data, dataLength, &sentLen);
308 if (CA_STATUS_OK != err)
310 OIC_LOG_V(ERROR, EDR_ADAPTER_TAG, "Send multicast data failed!, error num [%d]", err);
311 g_errorCallback(endpoint, data, dataLength, err);
315 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT - CASendEDRMulticastData");
319 CAResult_t CAGetEDRInterfaceInformation(CAEndpoint_t **info, uint32_t *size)
321 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
323 VERIFY_NON_NULL(info, EDR_ADAPTER_TAG, "LocalConnectivity info is null");
325 CAResult_t err = CA_STATUS_OK;
327 if (CA_STATUS_OK != (err = CAEDRGetInterfaceInformation(info)))
329 OIC_LOG_V(ERROR, EDR_ADAPTER_TAG,
330 "Failed to get local interface information!, error num [%d]", err);
335 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT");
339 CAResult_t CAReadEDRData()
341 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
343 return CAEDRManagerReadData();
346 CAResult_t CAStopEDR()
348 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
350 // Stop RFComm server if it is running
353 // Stop network monitor
354 CAEDRStopNetworkMonitor();
357 CAEDRClientUnsetCallbacks();
359 // Disconnect all the client connections
360 CAEDRClientDisconnectAll();
362 // Stop Send and receive Queue
363 CAAdapterStopQueue();
365 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT");
369 void CATerminateEDR()
371 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
375 // Terminate EDR Network Monitor
376 CAEDRTerminateNetworkMonitor();
378 // Terminate Send/Receive data messages queues
379 CAAdapterTerminateQueues();
381 g_networkPacketReceivedCallback = NULL;
382 g_networkChangeCallback = NULL;
384 // Terminate thread pool
385 g_edrThreadPool = NULL;
387 // Terminate EDR Client
388 CAEDRClientTerminate();
390 // Terminate EDR Server
391 CAEDRServerTerminate();
393 // Free LocalConnectivity information
394 CAFreeEndpoint(g_localConnectivity);
395 g_localConnectivity = NULL;
397 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT");
400 CAResult_t CAStartServer()
402 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
404 CAResult_t err = CA_STATUS_OK;
406 if (false == g_adapterState)
408 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "Bluetooth adapter is disabled!");
409 // Setting g_serverState for starting Rfcommserver when adapter starts
410 g_serverState = true;
414 if (CA_STATUS_OK != (err = CAEDRServerStart(g_edrThreadPool)))
416 OIC_LOG_V(ERROR, EDR_ADAPTER_TAG, "Failed to start RFCOMM server!, error num [%d]",
421 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT");
425 CAResult_t CAEDRInitializeQueueHandlers()
427 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
429 if (CA_STATUS_OK == CAEDRInitializeSendHandler()
430 && CA_STATUS_OK == CAEDRInitializeReceiveHandler())
432 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "Queue is initialized!");
436 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT");
437 return CA_STATUS_FAILED;
440 CAResult_t CAEDRInitializeSendHandler()
442 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
443 // Check if the message queue is already initialized
444 if (g_sendQueueHandle)
446 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "Already queue is initialized!");
450 g_sendQueueHandle = (CAQueueingThread_t *) OICMalloc(sizeof(CAQueueingThread_t));
451 if (!g_sendQueueHandle)
453 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Memory allocation failed!");
454 return CA_MEMORY_ALLOC_FAILED;
457 if (CA_STATUS_OK != CAQueueingThreadInitialize(g_sendQueueHandle, g_edrThreadPool,
458 CAAdapterDataSendHandler, CAEDRDataDestroyer))
460 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Failed to Initialize send queue thread");
461 return CA_STATUS_FAILED;
466 CAResult_t CAEDRInitializeReceiveHandler()
468 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
469 // Check if the message queue is already initialized
470 if (g_recvQueueHandle)
472 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "Already queue is initialized!");
476 g_recvQueueHandle = (CAQueueingThread_t *) OICMalloc(sizeof(CAQueueingThread_t));
477 if (!g_recvQueueHandle)
479 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Memory allocation failed!");
480 return CA_MEMORY_ALLOC_FAILED;
483 if (CA_STATUS_OK != CAQueueingThreadInitialize(g_recvQueueHandle, g_edrThreadPool,
484 CAAdapterDataReceiverHandler,
487 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Failed to Initialize send queue thread");
488 return CA_STATUS_FAILED;
491 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT");
495 void CAAdapterTerminateQueues()
497 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
499 if (g_sendQueueHandle)
501 CAQueueingThreadDestroy(g_sendQueueHandle);
502 g_sendQueueHandle = NULL;
504 if (g_recvQueueHandle)
506 CAQueueingThreadDestroy(g_recvQueueHandle);
507 g_recvQueueHandle = NULL;
510 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT");
513 void CAAdapterDataSendHandler(void *context)
515 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN - CAAdapterDataSendHandler");
517 CAEDRData *message = (CAEDRData *) context;
520 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Failed to get message!");
524 const char *remoteAddress = NULL;
526 if (NULL == message->remoteEndpoint)
528 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "remoteEndpoint is not available");
533 remoteAddress = message->remoteEndpoint->addr;
538 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "EDR Send Message error");
539 //Error cannot be sent if remote address is NULL
543 CAResult_t result = CAEDRClientSendData(remoteAddress, message->data,
545 if(CA_STATUS_OK != result)
547 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "CAEDRClientSendData API failed");
548 CAEDRErrorHandler(remoteAddress, message->data, message->dataLen, result);
552 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT");
555 CAResult_t CAEDRClientSendData(const char *remoteAddress,
560 CAResult_t result = CA_SEND_FAILED;
562 // Send the first segment with the header.
563 if ((NULL != remoteAddress) && (0 < strlen(remoteAddress))) //Unicast data
565 result = CAEDRClientSendUnicastData(remoteAddress, data, dataLength);
566 if (CA_STATUS_OK != result)
568 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Failed to send unicast data !");
574 OIC_LOG_V(DEBUG, EDR_ADAPTER_TAG, "sending multicast data : %s", data);
575 result = CAEDRClientSendMulticastData(data, dataLength);
577 if (CA_STATUS_OK != result)
579 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Failed to send multicast data !");
586 void CAAdapterDataReceiverHandler(void *context)
588 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN_CAAdapterDataReceiverHandler");
590 CAEDRData *message = (CAEDRData *) context;
591 if (NULL == message || NULL == message->remoteEndpoint)
593 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Failed to get message!");
597 CAEndpoint_t *remoteEndpoint = CACreateEndpointObject(CA_DEFAULT_FLAGS,
598 CA_ADAPTER_RFCOMM_BTEDR,
599 message->remoteEndpoint->addr,
602 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "Sending data up !");
603 g_networkPacketReceivedCallback(remoteEndpoint, message->data, message->dataLen);
605 CAFreeEndpoint(remoteEndpoint);
607 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT_CAAdapterDataReceiverHandler");
610 CAResult_t CAAdapterStartQueue()
612 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
613 // Start send queue thread
614 if (CA_STATUS_OK != CAQueueingThreadStart(g_sendQueueHandle))
616 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Failed to Start Send Data Thread");
617 CAEDRClientUnsetCallbacks();
618 //Disconnect all the client connections
619 CAEDRClientDisconnectAll();
620 return CA_STATUS_FAILED;
623 // Start receive queue thread
624 if (CA_STATUS_OK != CAQueueingThreadStart(g_recvQueueHandle))
626 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Failed to Start Receive Data Thread");
627 CAEDRClientUnsetCallbacks();
628 //Disconnect all the client connections
629 CAEDRClientDisconnectAll();
630 return CA_STATUS_FAILED;
632 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT");
636 CAResult_t CAAdapterStopQueue()
638 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
639 //Stop send queue thread
640 CAQueueingThreadStop(g_sendQueueHandle);
642 //Stop receive queue thread
643 CAQueueingThreadStop(g_recvQueueHandle);
644 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT");
648 void CAAdapterRecvData(const char *remoteAddress, const uint8_t *data, uint32_t dataLength,
649 uint32_t *sentLength)
651 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
653 if (false == g_adapterState)
655 OIC_LOG_V(ERROR, EDR_ADAPTER_TAG, "Bluetooth adapter is disabled!");
661 VERIFY_NON_NULL_VOID(data, EDR_ADAPTER_TAG, "Data is null");
662 VERIFY_NON_NULL_VOID(sentLength, EDR_ADAPTER_TAG, "Sent data length holder is null");
664 // Create remote endpoint
665 CAEndpoint_t *remoteEndpoint = CACreateEndpointObject(CA_DEFAULT_FLAGS,
666 CA_ADAPTER_RFCOMM_BTEDR,
668 if (NULL == remoteEndpoint)
670 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Failed to create remote endpoint !");
674 // Add message to data queue
675 CAEDRData *edrData = CACreateEDRData(remoteEndpoint, data, dataLength);
676 CAQueueingThreadAddData(g_recvQueueHandle, edrData, sizeof(CAEDRData));
677 *sentLength = dataLength;
679 // Free remote endpoint
680 CAFreeEndpoint(remoteEndpoint);
682 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT");
685 void CAEDRErrorHandler(const char *remoteAddress, const uint8_t *data,
686 uint32_t dataLength, CAResult_t result)
688 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
691 VERIFY_NON_NULL_VOID(data, EDR_ADAPTER_TAG, "Data is null");
693 // Create remote endpoint
694 CAEndpoint_t *remoteEndpoint = CACreateEndpointObject(0, CA_ADAPTER_RFCOMM_BTEDR,
698 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Failed to create remote endpoint !");
702 g_errorCallback(remoteEndpoint, data, dataLength, result);
704 // Free remote endpoint
705 CAFreeEndpoint(remoteEndpoint);
707 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT");
710 CAResult_t CAAdapterSendData(const char *remoteAddress, const char *serviceUUID, const uint8_t *data,
711 uint32_t dataLength, uint32_t *sentLength)
713 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN - CAAdapterSendData");
715 if (false == g_adapterState)
717 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Bluetooth adapter is disabled!");
719 return CA_ADAPTER_NOT_ENABLED;
722 VERIFY_NON_NULL(serviceUUID, EDR_ADAPTER_TAG, "service UUID is null");
723 VERIFY_NON_NULL(data, EDR_ADAPTER_TAG, "Data is null");
724 VERIFY_NON_NULL(sentLength, EDR_ADAPTER_TAG, "Sent data length holder is null");
726 // Create remote endpoint
727 CAEndpoint_t *remoteEndpoint = CACreateEndpointObject(CA_DEFAULT_FLAGS,
728 CA_ADAPTER_RFCOMM_BTEDR,
730 if (NULL == remoteEndpoint)
732 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Failed to create remote endpoint !");
733 return CA_MEMORY_ALLOC_FAILED;
736 // Add message to data queue
737 CAEDRData *edrData = CACreateEDRData(remoteEndpoint, data, dataLength);
738 CAQueueingThreadAddData(g_sendQueueHandle, edrData, sizeof (CAEDRData));
739 *sentLength = dataLength;
741 // Free remote endpoint
742 CAFreeEndpoint(remoteEndpoint);
744 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT - CAAdapterSendData");
748 void CAEDRNotifyNetworkStatus(CANetworkStatus_t status)
750 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
752 // Create localconnectivity
753 if (NULL == g_localConnectivity)
755 CAEDRGetInterfaceInformation(&g_localConnectivity);
758 if (CA_INTERFACE_UP == status)
760 if (false == g_adapterState)
762 // Get Bluetooth adapter state
763 bool adapterState = false;
764 if (CA_STATUS_OK != CAEDRGetAdapterEnableState(&adapterState))
766 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Failed to get adapter enable state");
770 if (false== adapterState)
772 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Bluetooth adapter is disabled!");
773 g_adapterState = false;
776 CAEDRClientSetCallbacks();
777 g_adapterState = true;
778 CAAdapterStartQueue();
779 // starting RFCommServer
780 if (true == g_serverState)
783 g_serverState = false;
789 g_adapterState = false;
792 // Notify to upper layer
793 if (g_networkChangeCallback && g_localConnectivity && g_edrThreadPool)
795 // Add notification task to thread pool
796 CAEDRNetworkEvent *event = CAEDRCreateNetworkEvent(g_localConnectivity, status);
799 if (CA_STATUS_OK != ca_thread_pool_add_task(g_edrThreadPool,
800 CAEDROnNetworkStatusChanged,event))
802 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Failed to create threadpool!");
808 OIC_LOG_V(DEBUG, EDR_ADAPTER_TAG, "OUT");
811 void CAEDROnNetworkStatusChanged(void *context)
813 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
817 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "context is NULL!");
821 CAEDRNetworkEvent *networkEvent = (CAEDRNetworkEvent *) context;
823 // Notify to upper layer
824 if (g_networkChangeCallback)
826 g_networkChangeCallback(networkEvent->info, networkEvent->status);
829 // Free the created Network event
830 CAEDRFreeNetworkEvent(networkEvent);
832 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT");
835 CAEDRNetworkEvent *CAEDRCreateNetworkEvent(CAEndpoint_t *connectivity,
836 CANetworkStatus_t status)
838 VERIFY_NON_NULL_RET(connectivity, EDR_ADAPTER_TAG, "connectivity is NULL", NULL);
840 // Create CAEDRNetworkEvent
841 CAEDRNetworkEvent *event = (CAEDRNetworkEvent *) OICMalloc(sizeof(CAEDRNetworkEvent));
844 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Failed to allocate memory to network event!");
848 // Create duplicate of Local connectivity
849 event->info = CACloneEndpoint(connectivity);
850 event->status = status;
854 void CAEDRFreeNetworkEvent(CAEDRNetworkEvent *event)
858 CAFreeEndpoint(event->info);
863 CAEDRData *CACreateEDRData(const CAEndpoint_t *remoteEndpoint,
864 const uint8_t *data, uint32_t dataLength)
866 CAEDRData *edrData = (CAEDRData *)OICMalloc(sizeof (CAEDRData));
869 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Memory allocation failed!");
873 edrData->remoteEndpoint = CACloneEndpoint(remoteEndpoint);
875 edrData->data = OICMalloc(dataLength);
876 if (NULL == edrData->data)
878 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Memory allocation failed!");
879 CAFreeEDRData(edrData);
882 memcpy(edrData->data, data, dataLength);
883 edrData->dataLen = dataLength;
888 void CAFreeEDRData(CAEDRData *edrData)
890 VERIFY_NON_NULL_VOID(edrData, EDR_ADAPTER_TAG, "edrData is NULL");
892 CAFreeEndpoint(edrData->remoteEndpoint);
893 OICFree(edrData->data);
897 void CAEDRDataDestroyer(void *data, uint32_t size)
899 if ((size_t)size < sizeof(CAEDRData))
901 OIC_LOG_V(ERROR, EDR_ADAPTER_TAG, "Destroy data too small %p %d",
904 CAEDRData *edrdata = (CAEDRData *) data;
906 CAFreeEDRData(edrdata);