| /****************************************************************************** |
| * |
| * 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 <base/strings/stringprintf.h> |
| |
| #include <cstdint> |
| #include <string> |
| |
| #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 */ |