1 /******************************************************************************
2  *
3  *  Copyright (C) 2014 The Android Open Source Project
4  *
5  *  Licensed under the Apache License, Version 2.0 (the "License");
6  *  you may not use this file except in compliance with the License.
7  *  You may obtain a copy of the License at:
8  *
9  *  http://www.apache.org/licenses/LICENSE-2.0
10  *
11  *  Unless required by applicable law or agreed to in writing, software
12  *  distributed under the License is distributed on an "AS IS" BASIS,
13  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  *  See the License for the specific language governing permissions and
15  *  limitations under the License.
16  *
17  ******************************************************************************/
18 
19 /******************************************************************************
20  *
21  *  This is the implementation of the API for SDP search subsystem
22  *
23  ******************************************************************************/
24 
25 #include "common/bt_target.h"
26 #include "bta/bta_api.h"
27 #include "bta/bta_sys.h"
28 #include "bta/bta_sdp_api.h"
29 #include "bta_sdp_int.h"
30 #include <string.h>
31 #include "osi/allocator.h"
32 #include "stack/sdp_api.h"
33 
34 #if defined(BTA_SDP_INCLUDED) && (BTA_SDP_INCLUDED == TRUE)
35 /*****************************************************************************
36 **  Constants
37 *****************************************************************************/
38 
39 static const tBTA_SYS_REG bta_sdp_reg = {
40     bta_sdp_sm_execute,
41     NULL
42 };
43 
44 /*******************************************************************************
45 **
46 ** Function         BTA_SdpEnable
47 **
48 ** Description      Enable the SDP search I/F service. When the enable
49 **                  operation is complete the callback function will be
50 **                  called with a BTA_SDP_ENABLE_EVT. This function must
51 **                  be called before other functions in the SDP search API are
52 **                  called.
53 **
54 ** Returns          BTA_SDP_SUCCESS if successful.
55 **                  BTA_SDP_FAIL if internal failure.
56 **
57 *******************************************************************************/
BTA_SdpEnable(tBTA_SDP_DM_CBACK * p_cback)58 tBTA_SDP_STATUS BTA_SdpEnable(tBTA_SDP_DM_CBACK *p_cback)
59 {
60     tBTA_SDP_STATUS status = BTA_SDP_FAILURE;
61     tBTA_SDP_API_ENABLE  *p_buf;
62 
63     APPL_TRACE_API("%s\n", __FUNCTION__);
64 
65 #if BTA_DYNAMIC_MEMORY == TRUE
66     /* Malloc buffer for SDP configuration structure */
67     p_bta_sdp_cfg->p_sdp_db = (tSDP_DISCOVERY_DB *)osi_malloc(p_bta_sdp_cfg->sdp_db_size);
68     if (p_bta_sdp_cfg->p_sdp_db == NULL) {
69         return BTA_SDP_FAILURE;
70     }
71 #endif
72 
73     if (p_cback && FALSE == bta_sys_is_register(BTA_ID_SDP)) {
74         memset(&bta_sdp_cb, 0, sizeof(tBTA_SDP_CB));
75 
76         /* register with BTA system manager */
77         bta_sys_register(BTA_ID_SDP, &bta_sdp_reg);
78 
79         if (p_cback &&
80                 (p_buf = (tBTA_SDP_API_ENABLE *) osi_malloc(sizeof(tBTA_SDP_API_ENABLE))) != NULL) {
81             p_buf->hdr.event = BTA_SDP_API_ENABLE_EVT;
82             p_buf->p_cback = p_cback;
83             bta_sys_sendmsg(p_buf);
84             status = BTA_SDP_SUCCESS;
85         }
86     }
87     return (status);
88 }
89 
90 
91 /*******************************************************************************
92 **
93 ** Function         BTA_SdpDisable
94 **
95 ** Description      Disable the SDP search I/F service.
96 **                  Free buffer for SDP configuration structure.
97 **
98 ** Returns          BTA_SDP_SUCCESS if successful.
99 **                  BTA_SDP_FAIL if internal failure.
100 **
101 *******************************************************************************/
BTA_SdpDisable(void)102 tBTA_SDP_STATUS BTA_SdpDisable(void)
103 {
104     tBTA_SDP_STATUS status = BTA_SDP_SUCCESS;
105 
106     bta_sys_deregister(BTA_ID_SDP);
107 #if BTA_DYNAMIC_MEMORY == TRUE
108     /* Free buffer for SDP configuration structure */
109     osi_free(p_bta_sdp_cfg->p_sdp_db);
110     p_bta_sdp_cfg->p_sdp_db = NULL;
111 #endif
112     return (status);
113 }
114 
115 /*******************************************************************************
116 **
117 ** Function         BTA_SdpSearch
118 **
119 ** Description      This function performs service discovery for a specific service
120 **                  on given peer device. When the operation is completed
121 **                  the tBTA_SDP_DM_CBACK callback function will be  called with
122 **                  a BTA_SDP_SEARCH_COMPLETE_EVT.
123 **
124 ** Returns          BTA_SDP_SUCCESS, if the request is being processed.
125 **                  BTA_SDP_FAILURE, otherwise.
126 **
127 *******************************************************************************/
BTA_SdpSearch(BD_ADDR bd_addr,tSDP_UUID * uuid)128 tBTA_SDP_STATUS BTA_SdpSearch(BD_ADDR bd_addr, tSDP_UUID *uuid)
129 {
130     tBTA_SDP_STATUS ret = BTA_SDP_FAILURE;
131     tBTA_SDP_API_SEARCH *p_msg;
132 
133     APPL_TRACE_API("%s\n", __FUNCTION__);
134     if ((p_msg = (tBTA_SDP_API_SEARCH *)osi_malloc(sizeof(tBTA_SDP_API_SEARCH))) != NULL) {
135         p_msg->hdr.event = BTA_SDP_API_SEARCH_EVT;
136         bdcpy(p_msg->bd_addr, bd_addr);
137         //p_msg->uuid = uuid;
138         memcpy(&(p_msg->uuid), uuid, sizeof(tSDP_UUID));
139         bta_sys_sendmsg(p_msg);
140         ret = BTA_SDP_SUCCESS;
141     }
142 
143     return (ret);
144 }
145 
146 /*******************************************************************************
147 **
148 ** Function         BTA_SdpCreateRecordByUser
149 **
150 ** Description      This function is used to request a callback to create a SDP
151 **                  record. The registered callback will be called with event
152 **                  BTA_SDP_CREATE_RECORD_USER_EVT.
153 **
154 ** Returns          BTA_SDP_SUCCESS, if the request is being processed.
155 **                  BTA_SDP_FAILURE, otherwise.
156 **
157 *******************************************************************************/
BTA_SdpCreateRecordByUser(void * user_data)158 tBTA_SDP_STATUS BTA_SdpCreateRecordByUser(void *user_data)
159 {
160     tBTA_SDP_STATUS ret = BTA_SDP_FAILURE;
161     tBTA_SDP_API_RECORD_USER *p_msg;
162 
163     APPL_TRACE_API("%s\n", __FUNCTION__);
164     if ((p_msg = (tBTA_SDP_API_RECORD_USER *)osi_malloc(sizeof(tBTA_SDP_API_RECORD_USER))) != NULL) {
165         p_msg->hdr.event = BTA_SDP_API_CREATE_RECORD_USER_EVT;
166         p_msg->user_data = user_data;
167         bta_sys_sendmsg(p_msg);
168         ret = BTA_SDP_SUCCESS;
169     }
170 
171     return (ret);
172 }
173 
174 /*******************************************************************************
175 **
176 ** Function         BTA_SdpRemoveRecordByUser
177 **
178 ** Description      This function is used to request a callback to remove a SDP
179 **                  record. The registered callback will be called with event
180 **                  BTA_SDP_REMOVE_RECORD_USER_EVT.
181 **
182 ** Returns          BTA_SDP_SUCCESS, if the request is being processed.
183 **                  BTA_SDP_FAILURE, otherwise.
184 **
185 *******************************************************************************/
BTA_SdpRemoveRecordByUser(void * user_data)186 tBTA_SDP_STATUS BTA_SdpRemoveRecordByUser(void *user_data)
187 {
188     tBTA_SDP_STATUS ret = BTA_SDP_FAILURE;
189     tBTA_SDP_API_RECORD_USER *p_msg;
190 
191     APPL_TRACE_API("%s\n", __FUNCTION__);
192     if ((p_msg = (tBTA_SDP_API_RECORD_USER *)osi_malloc(sizeof(tBTA_SDP_API_RECORD_USER))) != NULL) {
193         p_msg->hdr.event = BTA_SDP_API_REMOVE_RECORD_USER_EVT;
194         p_msg->user_data = user_data;
195         bta_sys_sendmsg(p_msg);
196         ret = BTA_SDP_SUCCESS;
197     }
198 
199     return (ret);
200 }
201 
202 
203 #endif /* #if defined(BTA_SDP_INCLUDED) && (BTA_SDP_INCLUDED == TRUE) */
204