2016-10-21 03:12:22 -04:00
|
|
|
/******************************************************************************
|
|
|
|
*
|
|
|
|
* Copyright (C) 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 "bt_sdp.h"
|
2018-04-08 00:10:50 -04:00
|
|
|
#include "common/bt_target.h"
|
|
|
|
#include "stack/bt_types.h"
|
|
|
|
#include "bta/bta_api.h"
|
|
|
|
#include "stack/btm_api.h"
|
2016-10-21 03:12:22 -04:00
|
|
|
|
2017-04-17 22:53:43 -04:00
|
|
|
#if (SDP_INCLUDED == TRUE)
|
2016-10-21 03:12:22 -04:00
|
|
|
/* status values */
|
|
|
|
#define BTA_SDP_SUCCESS 0 /* Successful operation. */
|
|
|
|
#define BTA_SDP_FAILURE 1 /* Generic failure. */
|
|
|
|
#define BTA_SDP_BUSY 2 /* Temporarily can not handle this request. */
|
|
|
|
|
|
|
|
typedef UINT8 tBTA_SDP_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 tBTA_SDP_EVT;
|
|
|
|
|
|
|
|
/* data associated with BTA_SDP_DISCOVERY_COMP_EVT */
|
2016-11-24 13:10:15 -05:00
|
|
|
typedef struct {
|
2016-10-21 03:12:22 -04:00
|
|
|
tBTA_SDP_STATUS status;
|
|
|
|
BD_ADDR remote_addr;
|
|
|
|
tBT_UUID uuid;
|
|
|
|
int record_count;
|
|
|
|
bluetooth_sdp_record records[BTA_SDP_MAX_RECORDS];
|
|
|
|
} tBTA_SDP_SEARCH_COMP;
|
|
|
|
|
2016-11-24 13:10:15 -05:00
|
|
|
typedef union {
|
2016-10-21 03:12:22 -04:00
|
|
|
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 */
|
2016-11-24 13:10:15 -05:00
|
|
|
typedef void (tBTA_SDP_DM_CBACK)(tBTA_SDP_EVT event, tBTA_SDP *p_data, void *user_data);
|
2016-10-21 03:12:22 -04:00
|
|
|
|
|
|
|
/* MCE configuration structure */
|
2016-11-24 13:10:15 -05:00
|
|
|
typedef struct {
|
2016-10-21 03:12:22 -04:00
|
|
|
UINT16 sdp_db_size; /* The size of p_sdp_db */
|
2017-04-17 22:53:43 -04:00
|
|
|
#if (SDP_INCLUDED == TRUE)
|
2016-10-21 03:12:22 -04:00
|
|
|
tSDP_DISCOVERY_DB *p_sdp_db; /* The data buffer to keep SDP database */
|
2017-04-17 22:53:43 -04:00
|
|
|
#endif ///SDP_INCLUDED == TRUE
|
2016-10-21 03:12:22 -04:00
|
|
|
} tBTA_SDP_CFG;
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C"
|
|
|
|
{
|
|
|
|
#endif
|
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** 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.
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
|
|
|
extern 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.
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
2016-11-24 13:10:15 -05:00
|
|
|
extern tBTA_SDP_STATUS BTA_SdpSearch(BD_ADDR bd_addr, tSDP_UUID *uuid);
|
2016-10-21 03:12:22 -04:00
|
|
|
|
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** 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.
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
2016-11-24 13:10:15 -05:00
|
|
|
extern tBTA_SDP_STATUS BTA_SdpCreateRecordByUser(void *user_data);
|
2016-10-21 03:12:22 -04:00
|
|
|
|
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** 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.
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
2016-11-24 13:10:15 -05:00
|
|
|
extern tBTA_SDP_STATUS BTA_SdpRemoveRecordByUser(void *user_data);
|
2016-10-21 03:12:22 -04:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2017-04-17 22:53:43 -04:00
|
|
|
#endif ///SDP_INCLUDED == TRUE
|
|
|
|
|
2016-10-21 03:12:22 -04:00
|
|
|
#endif /* BTA_SDP_API_H */
|