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 ******************************************************************/
23 * @brief This file provides the APIs to start and stop RFCOMM server.
28 #include <bluetooth.h>
29 #include "caedrinterface.h"
31 #include "caadapterutils.h"
32 #include "caedrutils.h"
36 #include "caedrdevicelist.h"
38 static int32_t gMaxPendingConnections = 10;
40 CAResult_t CAEDRServerStart(const char *serviceUUID, int32_t *serverFD, u_thread_pool_t handle)
42 OIC_LOG_V(DEBUG, EDR_ADAPTER_TAG, "IN");
44 bt_error_e err = BT_ERROR_NONE;
45 bool isRunning = false;
48 VERIFY_NON_NULL(serviceUUID, EDR_ADAPTER_TAG, "Service UUID is null");
49 VERIFY_NON_NULL(serverFD, EDR_ADAPTER_TAG, "Server fd holder is null");
51 if (0 >= strlen(serviceUUID))
53 OIC_LOG_V(ERROR, EDR_ADAPTER_TAG, "Invalid input: Empty service uuid!");
54 return CA_STATUS_INVALID_PARAM;
57 if (BT_ERROR_NONE != bt_adapter_is_service_used(serviceUUID, &isRunning))
59 OIC_LOG_V(DEBUG, EDR_ADAPTER_TAG,
60 "Unable to find whether service is already running or not!");
61 return CA_STATUS_FAILED;
64 if (true == isRunning)
66 OIC_LOG_V(DEBUG, EDR_ADAPTER_TAG, "Service is already running with this UUID!");
67 return CA_SERVER_STARTED_ALREADY;
70 // Registers a rfcomm socket with a specific service_uuid .
71 if (BT_ERROR_NONE != (err = bt_socket_create_rfcomm(serviceUUID, &socketFD)))
73 OIC_LOG_V(ERROR, EDR_ADAPTER_TAG, "Failed to create rfcomm socket!, error num [%x]",
75 return CA_STATUS_FAILED;
78 // Start listening and accepting
79 if (BT_ERROR_NONE != (err = bt_socket_listen_and_accept_rfcomm(socketFD,
80 gMaxPendingConnections)))
82 OIC_LOG_V(ERROR, EDR_ADAPTER_TAG, "Failed in listen rfcomm socket!, error num [%x]",
85 bt_socket_destroy_rfcomm(socketFD);
86 return CA_STATUS_FAILED;
91 OIC_LOG_V(DEBUG, EDR_ADAPTER_TAG, "OUT");
95 CAResult_t CAEDRServerStop(const int32_t serverFD)
97 OIC_LOG_V(DEBUG, EDR_ADAPTER_TAG, "IN");
99 bt_error_e err = BT_ERROR_NONE;
100 if (BT_ERROR_NONE != (err = bt_socket_destroy_rfcomm(serverFD)))
102 OIC_LOG_V(ERROR, EDR_ADAPTER_TAG, "Failed close server socket!, error num [%x]",
104 return CA_STATUS_FAILED;
107 OIC_LOG_V(DEBUG, EDR_ADAPTER_TAG, "OUT");
111 CAResult_t CAEDRManagerReadData(void)
113 OIC_LOG_V(DEBUG, EDR_ADAPTER_TAG, "IN");
114 OIC_LOG_V(DEBUG, EDR_ADAPTER_TAG, "OUT");
115 return CA_NOT_SUPPORTED;