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 provides the APIs to send data on established RFCOMM connections.
27 #include "caedrendpoint.h"
28 #include "caadapterutils.h"
29 #include "caedrutils.h"
32 CAResult_t CAEDRSendData(int serverFD, const char *addr, const void *data, uint32_t dataLength)
34 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "IN");
36 VERIFY_NON_NULL(data, EDR_ADAPTER_TAG, "Data is null");
37 VERIFY_NON_NULL(addr, EDR_ADAPTER_TAG, "Addr is null");
41 OIC_LOG(ERROR, EDR_ADAPTER_TAG, "Invalid input: Negative socket id");
42 return CA_STATUS_INVALID_PARAM;
45 int dataLen = bt_socket_send_data(serverFD, (const char *)data, dataLength);
46 int errcode = get_last_result();
48 if (TIZEN_ERROR_NONE == errcode)
50 CALogSendStateInfo(CA_ADAPTER_RFCOMM_BTEDR, addr, 0, dataLength, true, NULL);
56 OIC_LOG_V(ERROR, EDR_ADAPTER_TAG, "sending data failed!, soketid [%d] errmsg [%s]",
57 serverFD, get_error_message(errcode));
59 else if (dataLen == 0)
61 OIC_LOG_V(ERROR, EDR_ADAPTER_TAG, "soketid [%d] may be disconnected? errmsg [%s]",
62 serverFD, get_error_message(errcode));
65 CALogSendStateInfo(CA_ADAPTER_RFCOMM_BTEDR, addr, 0, dataLength,
66 false, get_error_message(errcode));
68 return CA_SOCKET_OPERATION_FAILED;
71 OIC_LOG(DEBUG, EDR_ADAPTER_TAG, "OUT");