/******************************************************************************
*
* Copyright 2015 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at:
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
******************************************************************************/
/******************************************************************************
*
* This is the public interface file for the BTA SDP I/F
*
******************************************************************************/
#ifndef BTA_SDP_API_H
#define BTA_SDP_API_H
#include
#include
#include
#include "include/hardware/bt_sdp.h" // bluetooth_sdp_record
#include "macros.h"
#include "stack/sdp/sdp_discovery_db.h"
#include "types/bluetooth/uuid.h"
#include "types/raw_address.h"
using bluetooth::Uuid;
/* status values */
typedef enum : uint8_t {
BTA_SDP_SUCCESS = 0, /* Successful operation. */
BTA_SDP_FAILURE = 1, /* Generic failure. */
BTA_SDP_BUSY = 2, /* Temporarily can not handle this request. */
} tBTA_SDP_STATUS;
inline std::string bta_sdp_status_text(const tBTA_SDP_STATUS& status) {
switch (status) {
CASE_RETURN_TEXT(BTA_SDP_SUCCESS);
CASE_RETURN_TEXT(BTA_SDP_FAILURE);
CASE_RETURN_TEXT(BTA_SDP_BUSY);
default:
return base::StringPrintf("UNKNOWN[%d]", status);
}
}
/* SDP I/F callback events */
/* events received by tBTA_SDP_DM_CBACK */
#define BTA_SDP_ENABLE_EVT 0 /* SDP service i/f enabled*/
#define BTA_SDP_SEARCH_EVT 1 /* SDP Service started */
#define BTA_SDP_SEARCH_COMP_EVT 2 /* SDP search complete */
#define BTA_SDP_CREATE_RECORD_USER_EVT 3 /* SDP search complete */
#define BTA_SDP_REMOVE_RECORD_USER_EVT 4 /* SDP search complete */
#define BTA_SDP_MAX_EVT 5 /* max number of SDP events */
#define BTA_SDP_MAX_RECORDS 15
typedef uint16_t tBTA_SDP_EVT;
/* data associated with BTA_SDP_DISCOVERY_COMP_EVT */
typedef struct {
tBTA_SDP_STATUS status;
RawAddress remote_addr;
bluetooth::Uuid uuid;
int record_count;
bluetooth_sdp_record records[BTA_SDP_MAX_RECORDS];
} tBTA_SDP_SEARCH_COMP;
typedef union {
tBTA_SDP_STATUS status; /* BTA_SDP_SEARCH_EVT */
tBTA_SDP_SEARCH_COMP sdp_search_comp; /* BTA_SDP_SEARCH_COMP_EVT */
} tBTA_SDP;
/* SDP DM Interface callback */
typedef void(tBTA_SDP_DM_CBACK)(tBTA_SDP_EVT event, tBTA_SDP* p_data,
void* user_data);
/* MCE configuration structure */
typedef struct {
uint16_t sdp_db_size; /* The size of p_sdp_db */
tSDP_DISCOVERY_DB* p_sdp_db; /* The data buffer to keep SDP database */
} tBTA_SDP_CFG;
/*******************************************************************************
*
* Function BTA_SdpEnable
*
* Description Enable the SDP I/F service. When the enable
* operation is complete the callback function will be
* called with a BTA_SDP_ENABLE_EVT. This function must
* be called before other functions in the MCE API are
* called.
*
* Returns BTA_SDP_SUCCESS if successful.
* BTA_SDP_FAIL if internal failure.
*
******************************************************************************/
tBTA_SDP_STATUS BTA_SdpEnable(tBTA_SDP_DM_CBACK* p_cback);
/*******************************************************************************
*
* Function BTA_SdpSearch
*
* Description Start a search for sdp records for a specific BD_ADDR with a
* specific profile uuid.
* When the search operation is completed, the callback
* function will be called with a BTA_SDP_SEARCH_EVT.
* Returns BTA_SDP_SUCCESS if successful.
* BTA_SDP_FAIL if internal failure.
*
******************************************************************************/
tBTA_SDP_STATUS BTA_SdpSearch(const RawAddress& bd_addr,
const bluetooth::Uuid& uuid);
/*******************************************************************************
*
* Function BTA_SdpCreateRecordByUser
*
* Description This function is used to request a callback to create a SDP
* record. The registered callback will be called with event
* BTA_SDP_CREATE_RECORD_USER_EVT.
*
* Returns BTA_SDP_SUCCESS, if the request is being processed.
* BTA_SDP_FAILURE, otherwise.
*
******************************************************************************/
tBTA_SDP_STATUS BTA_SdpCreateRecordByUser(void* user_data);
/*******************************************************************************
*
* Function BTA_SdpRemoveRecordByUser
*
* Description This function is used to request a callback to remove a SDP
* record. The registered callback will be called with event
* BTA_SDP_REMOVE_RECORD_USER_EVT.
*
* Returns BTA_SDP_SUCCESS, if the request is being processed.
* BTA_SDP_FAILURE, otherwise.
*
******************************************************************************/
tBTA_SDP_STATUS BTA_SdpRemoveRecordByUser(void* user_data);
#endif /* BTA_SDP_API_H */