1 /******************************************************************************
3 * Copyright (C) 2010-2012 Broadcom Corporation
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:
9 * http://www.apache.org/licenses/LICENSE-2.0
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.
17 ******************************************************************************/
19 /******************************************************************************
21 * This is the implementation of the API for GATT module of BTA.
23 ******************************************************************************/
25 #include "bt_target.h"
27 #if defined(BTA_GATT_INCLUDED) && (BTA_GATT_INCLUDED == TRUE)
30 #include "bt_common.h"
32 #include "bta_gatt_api.h"
33 #include "bta_gattc_int.h"
35 /*****************************************************************************
37 *****************************************************************************/
39 static const tBTA_SYS_REG bta_gattc_reg =
46 /*******************************************************************************
48 ** Function BTA_GATTC_Disable
50 ** Description This function is called to disable GATTC module
56 *******************************************************************************/
57 void BTA_GATTC_Disable(void)
59 if (bta_sys_is_register(BTA_ID_GATTC) == FALSE)
61 APPL_TRACE_WARNING("GATTC Module not enabled/already disabled");
65 BT_HDR *p_buf = (BT_HDR *)osi_malloc(sizeof(BT_HDR));
66 p_buf->event = BTA_GATTC_API_DISABLE_EVT;
68 bta_sys_sendmsg(p_buf);
69 bta_sys_deregister(BTA_ID_GATTC);
72 /*******************************************************************************
74 ** Function BTA_GATTC_AppRegister
76 ** Description This function is called to register application callbacks
77 ** with BTA GATTC module.
79 ** Parameters p_app_uuid - applicaiton UUID
80 ** p_client_cb - pointer to the application callback function.
84 *******************************************************************************/
85 void BTA_GATTC_AppRegister(tBT_UUID *p_app_uuid, tBTA_GATTC_CBACK *p_client_cb)
87 tBTA_GATTC_API_REG *p_buf =
88 (tBTA_GATTC_API_REG *)osi_malloc(sizeof(tBTA_GATTC_API_REG));
90 if (bta_sys_is_register(BTA_ID_GATTC) == FALSE)
91 bta_sys_register(BTA_ID_GATTC, &bta_gattc_reg);
93 p_buf->hdr.event = BTA_GATTC_API_REG_EVT;
94 if (p_app_uuid != NULL)
95 memcpy(&p_buf->app_uuid, p_app_uuid, sizeof(tBT_UUID));
96 p_buf->p_cback = p_client_cb;
98 bta_sys_sendmsg(p_buf);
101 /*******************************************************************************
103 ** Function BTA_GATTC_AppDeregister
105 ** Description This function is called to deregister an application
106 ** from BTA GATTC module.
108 ** Parameters client_if - client interface identifier.
112 *******************************************************************************/
113 void BTA_GATTC_AppDeregister(tBTA_GATTC_IF client_if)
115 tBTA_GATTC_API_DEREG *p_buf =
116 (tBTA_GATTC_API_DEREG *)osi_malloc(sizeof(tBTA_GATTC_API_DEREG));
118 p_buf->hdr.event = BTA_GATTC_API_DEREG_EVT;
119 p_buf->client_if = client_if;
121 bta_sys_sendmsg(p_buf);
124 /*******************************************************************************
126 ** Function BTA_GATTC_Open
128 ** Description Open a direct connection or add a background auto connection
131 ** Parameters client_if: server interface.
132 ** remote_bda: remote device BD address.
133 ** is_direct: direct connection or background auto connection
134 ** transport: Transport to be used for GATT connection (BREDR/LE)
138 *******************************************************************************/
139 void BTA_GATTC_Open(tBTA_GATTC_IF client_if, BD_ADDR remote_bda,
140 BOOLEAN is_direct, tBTA_GATT_TRANSPORT transport)
142 tBTA_GATTC_API_OPEN *p_buf =
143 (tBTA_GATTC_API_OPEN *) osi_malloc(sizeof(tBTA_GATTC_API_OPEN));
145 p_buf->hdr.event = BTA_GATTC_API_OPEN_EVT;
146 p_buf->client_if = client_if;
147 p_buf->is_direct = is_direct;
148 p_buf->transport = transport;
149 memcpy(p_buf->remote_bda, remote_bda, BD_ADDR_LEN);
151 bta_sys_sendmsg(p_buf);
154 /*******************************************************************************
156 ** Function BTA_GATTC_CancelOpen
158 ** Description Cancel a direct open connection or remove a background auto connection
161 ** Parameters client_if: server interface.
162 ** remote_bda: remote device BD address.
163 ** is_direct: direct connection or background auto connection
167 *******************************************************************************/
168 void BTA_GATTC_CancelOpen(tBTA_GATTC_IF client_if, BD_ADDR remote_bda, BOOLEAN is_direct)
170 tBTA_GATTC_API_CANCEL_OPEN *p_buf =
171 (tBTA_GATTC_API_CANCEL_OPEN *)osi_malloc(sizeof(tBTA_GATTC_API_CANCEL_OPEN));
173 p_buf->hdr.event = BTA_GATTC_API_CANCEL_OPEN_EVT;
174 p_buf->client_if = client_if;
175 p_buf->is_direct = is_direct;
176 memcpy(p_buf->remote_bda, remote_bda, BD_ADDR_LEN);
178 bta_sys_sendmsg(p_buf);
181 /*******************************************************************************
183 ** Function BTA_GATTC_Close
185 ** Description Close a connection to a GATT server.
187 ** Parameters conn_id: connectino ID to be closed.
191 *******************************************************************************/
192 void BTA_GATTC_Close(UINT16 conn_id)
194 BT_HDR *p_buf = (BT_HDR *)osi_malloc(sizeof(BT_HDR));
196 p_buf->event = BTA_GATTC_API_CLOSE_EVT;
197 p_buf->layer_specific = conn_id;
199 bta_sys_sendmsg(p_buf);
202 /*******************************************************************************
204 ** Function BTA_GATTC_ConfigureMTU
206 ** Description Configure the MTU size in the GATT channel. This can be done
207 ** only once per connection.
209 ** Parameters conn_id: connection ID.
210 ** mtu: desired MTU size to use.
214 *******************************************************************************/
215 void BTA_GATTC_ConfigureMTU (UINT16 conn_id, UINT16 mtu)
217 tBTA_GATTC_API_CFG_MTU *p_buf =
218 (tBTA_GATTC_API_CFG_MTU *)osi_malloc(sizeof(tBTA_GATTC_API_CFG_MTU));
220 p_buf->hdr.event = BTA_GATTC_API_CFG_MTU_EVT;
221 p_buf->hdr.layer_specific = conn_id;
224 bta_sys_sendmsg(p_buf);
227 /*******************************************************************************
229 ** Function BTA_GATTC_ServiceSearchRequest
231 ** Description This function is called to request a GATT service discovery
232 ** on a GATT server. This function report service search result
233 ** by a callback event, and followed by a service search complete
236 ** Parameters conn_id: connection ID.
237 ** p_srvc_uuid: a UUID of the service application is interested in.
238 ** If Null, discover for all services.
242 *******************************************************************************/
243 void BTA_GATTC_ServiceSearchRequest (UINT16 conn_id, tBT_UUID *p_srvc_uuid)
245 const size_t len = sizeof(tBTA_GATTC_API_SEARCH) + sizeof(tBT_UUID);
246 tBTA_GATTC_API_SEARCH *p_buf = (tBTA_GATTC_API_SEARCH *)osi_calloc(len);
248 p_buf->hdr.event = BTA_GATTC_API_SEARCH_EVT;
249 p_buf->hdr.layer_specific = conn_id;
251 p_buf->p_srvc_uuid = (tBT_UUID *)(p_buf + 1);
252 memcpy(p_buf->p_srvc_uuid, p_srvc_uuid, sizeof(tBT_UUID));
254 p_buf->p_srvc_uuid = NULL;
257 bta_sys_sendmsg(p_buf);
260 /*******************************************************************************
262 ** Function BTA_GATTC_GetServices
264 ** Description This function is called to find the services on the given server.
266 ** Parameters conn_id: connection ID which identify the server.
268 ** Returns returns list_t of tBTA_GATTC_SERVICE or NULL.
270 *******************************************************************************/
271 const list_t* BTA_GATTC_GetServices(UINT16 conn_id) {
272 return bta_gattc_get_services(conn_id);
275 /*******************************************************************************
277 ** Function BTA_GATTC_GetCharacteristic
279 ** Description This function is called to find the characteristic on the given server.
281 ** Parameters conn_id: connection ID which identify the server.
282 ** handle: characteristic handle
284 ** Returns returns pointer to tBTA_GATTC_CHARACTERISTIC or NULL.
286 *******************************************************************************/
287 const tBTA_GATTC_CHARACTERISTIC* BTA_GATTC_GetCharacteristic(UINT16 conn_id, UINT16 handle) {
288 return bta_gattc_get_characteristic(conn_id, handle);
291 /*******************************************************************************
293 ** Function BTA_GATTC_GetCharacteristic
295 ** Description This function is called to find the characteristic on the given server.
297 ** Parameters conn_id: connection ID which identify the server.
298 ** handle: descriptor handle
300 ** Returns returns pointer to tBTA_GATTC_DESCRIPTOR or NULL.
302 *******************************************************************************/
303 const tBTA_GATTC_DESCRIPTOR* BTA_GATTC_GetDescriptor(UINT16 conn_id, UINT16 handle) {
304 return bta_gattc_get_descriptor(conn_id, handle);
307 /*******************************************************************************
309 ** Function BTA_GATTC_GetGattDb
311 ** Description This function is called to get the GATT database.
313 ** Parameters conn_id: connection ID which identify the server.
314 ** db: output parameter which will contain the GATT database copy.
315 ** Caller is responsible for freeing it.
316 ** count: number of elements in database.
318 *******************************************************************************/
319 void BTA_GATTC_GetGattDb(UINT16 conn_id, UINT16 start_handle, UINT16 end_handle,
320 btgatt_db_element_t **db, int *count)
322 bta_gattc_get_gatt_db(conn_id, start_handle, end_handle, db, count);
325 /*******************************************************************************
327 ** Function BTA_GATTC_ReadCharacteristic
329 ** Description This function is called to read a service's characteristics of
330 ** the given characteritisc ID.
332 ** Parameters conn_id - connectino ID.
333 ** p_char_id - characteritic ID to read.
337 *******************************************************************************/
338 void BTA_GATTC_ReadCharacteristic(UINT16 conn_id, tBTA_GATTC_CHAR_ID *p_char_id,
339 tBTA_GATT_AUTH_REQ auth_req)
341 tBTA_GATTC_API_READ *p_buf =
342 (tBTA_GATTC_API_READ *)osi_calloc(sizeof(tBTA_GATTC_API_READ));
344 p_buf->hdr.event = BTA_GATTC_API_READ_EVT;
345 p_buf->hdr.layer_specific = conn_id;
346 p_buf->auth_req = auth_req;
348 memcpy(&p_buf->srvc_id, &p_char_id->srvc_id, sizeof(tBTA_GATT_SRVC_ID));
349 memcpy(&p_buf->char_id, &p_char_id->char_id, sizeof(tBTA_GATT_ID));
350 p_buf->p_descr_type = NULL;
352 bta_sys_sendmsg(p_buf);
355 /*******************************************************************************
357 ** Function BTA_GATTC_ReadCharDescr
359 ** Description This function is called to read a characteristics descriptor.
361 ** Parameters conn_id - connection ID.
362 ** p_char_descr_id - characteritic descriptor ID to read.
366 *******************************************************************************/
367 void BTA_GATTC_ReadCharDescr (UINT16 conn_id,
368 tBTA_GATTC_CHAR_DESCR_ID *p_descr_id,
369 tBTA_GATT_AUTH_REQ auth_req)
371 const size_t len = sizeof(tBTA_GATT_ID) + sizeof(tBTA_GATTC_API_READ);
372 tBTA_GATTC_API_READ *p_buf = (tBTA_GATTC_API_READ *)osi_calloc(len);
374 p_buf->hdr.event = BTA_GATTC_API_READ_EVT;
375 p_buf->hdr.layer_specific = conn_id;
376 p_buf->auth_req = auth_req;
378 memcpy(&p_buf->srvc_id, &p_descr_id->char_id.srvc_id, sizeof(tBTA_GATT_SRVC_ID));
379 memcpy(&p_buf->char_id, &p_descr_id->char_id.char_id, sizeof(tBTA_GATT_ID));
380 p_buf->p_descr_type = (tBTA_GATT_ID *)(p_buf + 1);
382 memcpy(p_buf->p_descr_type, &p_descr_id->descr_id, sizeof(tBTA_GATT_ID));
384 bta_sys_sendmsg(p_buf);
387 /*******************************************************************************
389 ** Function BTA_GATTC_ReadMultiple
391 ** Description This function is called to read multiple characteristic or
392 ** characteristic descriptors.
394 ** Parameters conn_id - connectino ID.
395 ** p_read_multi - pointer to the read multiple parameter.
399 *******************************************************************************/
400 void BTA_GATTC_ReadMultiple(UINT16 conn_id, tBTA_GATTC_MULTI *p_read_multi,
401 tBTA_GATT_AUTH_REQ auth_req)
403 const size_t len = sizeof(tBTA_GATTC_API_READ_MULTI) +
404 p_read_multi->num_attr * sizeof(tBTA_GATTC_ATTR_ID);
405 tBTA_GATTC_API_READ_MULTI *p_buf =
406 (tBTA_GATTC_API_READ_MULTI *)osi_calloc(len);
408 p_buf->hdr.event = BTA_GATTC_API_READ_MULTI_EVT;
409 p_buf->hdr.layer_specific = conn_id;
410 p_buf->auth_req = auth_req;
411 p_buf->num_attr = p_read_multi->num_attr;
413 if (p_buf->num_attr > 0) {
414 tBTA_GATTC_ATTR_ID *p_value;
415 p_buf->p_id_list = p_value = (tBTA_GATTC_ATTR_ID *)(p_buf + 1);
416 for (int i = 0; i < p_buf->num_attr; i++, p_value++) {
417 memcpy(p_value, &p_read_multi->id_list[i], sizeof(tBTA_GATTC_ATTR_ID));
421 bta_sys_sendmsg(p_buf);
424 /*******************************************************************************
426 ** Function BTA_GATTC_WriteCharValue
428 ** Description This function is called to write characteristic value.
430 ** Parameters conn_id - connection ID.
431 ** p_char_id - characteristic ID to write.
432 ** write_type - type of write.
433 ** len: length of the data to be written.
434 ** p_value - the value to be written.
438 *******************************************************************************/
439 void BTA_GATTC_WriteCharValue ( UINT16 conn_id,
440 tBTA_GATTC_CHAR_ID *p_char_id,
441 tBTA_GATTC_WRITE_TYPE write_type,
444 tBTA_GATT_AUTH_REQ auth_req)
446 tBTA_GATTC_API_WRITE *p_buf =
447 (tBTA_GATTC_API_WRITE *)osi_calloc(sizeof(tBTA_GATTC_API_WRITE) + len);
449 p_buf->hdr.event = BTA_GATTC_API_WRITE_EVT;
450 p_buf->hdr.layer_specific = conn_id;
451 p_buf->auth_req = auth_req;
453 memcpy(&p_buf->srvc_id, &p_char_id->srvc_id, sizeof(tBTA_GATT_SRVC_ID));
454 memcpy(&p_buf->char_id, &p_char_id->char_id, sizeof(tBTA_GATT_ID));
455 p_buf->p_descr_type = NULL;
457 p_buf->write_type = write_type;
460 if (p_value && len > 0) {
461 p_buf->p_value = (UINT8 *)(p_buf + 1);
462 memcpy(p_buf->p_value, p_value, len);
465 bta_sys_sendmsg(p_buf);
468 /*******************************************************************************
470 ** Function BTA_GATTC_WriteCharDescr
472 ** Description This function is called to write characteristic descriptor value.
474 ** Parameters conn_id - connection ID
475 ** p_char_descr_id - characteristic descriptor ID to write.
476 ** write_type - write type.
477 ** p_value - the value to be written.
481 *******************************************************************************/
482 void BTA_GATTC_WriteCharDescr (UINT16 conn_id,
483 tBTA_GATTC_CHAR_DESCR_ID *p_char_descr_id,
484 tBTA_GATTC_WRITE_TYPE write_type,
485 tBTA_GATT_UNFMT *p_data,
486 tBTA_GATT_AUTH_REQ auth_req)
488 size_t len = sizeof(tBTA_GATTC_API_WRITE) + sizeof(tBTA_GATT_ID);
493 tBTA_GATTC_API_WRITE *p_buf = (tBTA_GATTC_API_WRITE *)osi_calloc(len);
494 p_buf->hdr.event = BTA_GATTC_API_WRITE_EVT;
495 p_buf->hdr.layer_specific = conn_id;
496 p_buf->auth_req = auth_req;
498 memcpy(&p_buf->srvc_id, &p_char_descr_id->char_id.srvc_id, sizeof(tBTA_GATT_SRVC_ID));
499 memcpy(&p_buf->char_id, &p_char_descr_id->char_id.char_id, sizeof(tBTA_GATT_ID));
500 p_buf->p_descr_type = (tBTA_GATT_ID *)(p_buf + 1);
501 memcpy(p_buf->p_descr_type, &p_char_descr_id->descr_id, sizeof(tBTA_GATT_ID));
502 p_buf->write_type = write_type;
504 if (p_data && p_data->len != 0) {
505 p_buf->p_value = (UINT8 *)(p_buf->p_descr_type + 1);
506 p_buf->len = p_data->len;
507 /* pack the descr data */
508 memcpy(p_buf->p_value, p_data->p_value, p_data->len);
511 bta_sys_sendmsg(p_buf);
514 /*******************************************************************************
516 ** Function BTA_GATTC_PrepareWrite
518 ** Description This function is called to prepare write a characteristic value.
520 ** Parameters conn_id - connection ID.
521 ** p_char_id - GATT characteritic ID of the service.
522 ** offset - offset of the write value.
523 ** len: length of the data to be written.
524 ** p_value - the value to be written.
528 *******************************************************************************/
529 void BTA_GATTC_PrepareWrite (UINT16 conn_id, tBTA_GATTC_CHAR_ID *p_char_id,
530 UINT16 offset, UINT16 len, UINT8 *p_value,
531 tBTA_GATT_AUTH_REQ auth_req)
533 tBTA_GATTC_API_WRITE *p_buf =
534 (tBTA_GATTC_API_WRITE *)osi_calloc(sizeof(tBTA_GATTC_API_WRITE) + len);
536 p_buf->hdr.event = BTA_GATTC_API_WRITE_EVT;
537 p_buf->hdr.layer_specific = conn_id;
538 p_buf->auth_req = auth_req;
540 memcpy(&p_buf->srvc_id, &p_char_id->srvc_id, sizeof(tBTA_GATT_SRVC_ID));
541 memcpy(&p_buf->char_id, &p_char_id->char_id, sizeof(tBTA_GATT_ID));
542 p_buf->p_descr_type = NULL;
544 p_buf->write_type = BTA_GATTC_WRITE_PREPARE;
545 p_buf->offset = offset;
548 if (p_value && len > 0) {
549 p_buf->p_value = (UINT8 *)(p_buf + 1);
550 memcpy(p_buf->p_value, p_value, len);
553 bta_sys_sendmsg(p_buf);
556 /*******************************************************************************
558 ** Function BTA_GATTC_ExecuteWrite
560 ** Description This function is called to execute write a prepare write sequence.
562 ** Parameters conn_id - connection ID.
563 ** is_execute - execute or cancel.
567 *******************************************************************************/
568 void BTA_GATTC_ExecuteWrite (UINT16 conn_id, BOOLEAN is_execute)
570 tBTA_GATTC_API_EXEC *p_buf =
571 (tBTA_GATTC_API_EXEC *)osi_calloc(sizeof(tBTA_GATTC_API_EXEC));
573 p_buf->hdr.event = BTA_GATTC_API_EXEC_EVT;
574 p_buf->hdr.layer_specific = conn_id;
575 p_buf->is_execute = is_execute;
577 bta_sys_sendmsg(p_buf);
580 /*******************************************************************************
582 ** Function BTA_GATTC_SendIndConfirm
584 ** Description This function is called to send handle value confirmation.
586 ** Parameters conn_id - connection ID.
587 ** p_char_id - characteristic ID to confirm.
591 *******************************************************************************/
592 void BTA_GATTC_SendIndConfirm (UINT16 conn_id, tBTA_GATTC_CHAR_ID *p_char_id)
594 tBTA_GATTC_API_CONFIRM *p_buf =
595 (tBTA_GATTC_API_CONFIRM *)osi_calloc(sizeof(tBTA_GATTC_API_CONFIRM));
597 APPL_TRACE_API("%s conn_id=%d service uuid1=0x%x char uuid=0x%x",
598 __func__, conn_id, p_char_id->srvc_id.id.uuid.uu.uuid16,
599 p_char_id->char_id.uuid.uu.uuid16);
601 p_buf->hdr.event = BTA_GATTC_API_CONFIRM_EVT;
602 p_buf->hdr.layer_specific = conn_id;
604 memcpy(&p_buf->srvc_id, &p_char_id->srvc_id, sizeof(tBTA_GATT_SRVC_ID));
605 memcpy(&p_buf->char_id, &p_char_id->char_id, sizeof(tBTA_GATT_ID));
607 bta_sys_sendmsg(p_buf);
610 /*******************************************************************************
612 ** Function BTA_GATTC_RegisterForNotifications
614 ** Description This function is called to register for notification of a service.
616 ** Parameters client_if - client interface.
617 ** bda - target GATT server.
618 ** p_char_id - pointer to GATT characteristic ID.
620 ** Returns OK if registration succeed, otherwise failed.
622 *******************************************************************************/
623 tBTA_GATT_STATUS BTA_GATTC_RegisterForNotifications (tBTA_GATTC_IF client_if,
625 tBTA_GATTC_CHAR_ID *p_char_id)
627 tBTA_GATTC_RCB *p_clreg;
628 tBTA_GATT_STATUS status = BTA_GATT_ILLEGAL_PARAMETER;
633 APPL_TRACE_ERROR("deregistration failed, unknow char id");
637 if ((p_clreg = bta_gattc_cl_get_regcb(client_if)) != NULL)
639 for (i = 0; i < BTA_GATTC_NOTIF_REG_MAX; i ++)
641 if ( p_clreg->notif_reg[i].in_use &&
642 !memcmp(p_clreg->notif_reg[i].remote_bda, bda, BD_ADDR_LEN) &&
643 bta_gattc_charid_compare(&p_clreg->notif_reg[i].char_id, p_char_id))
645 APPL_TRACE_WARNING("notification already registered");
646 status = BTA_GATT_OK;
650 if (status != BTA_GATT_OK)
652 for (i = 0; i < BTA_GATTC_NOTIF_REG_MAX; i ++)
654 if (!p_clreg->notif_reg[i].in_use)
656 memset((void *)&p_clreg->notif_reg[i], 0, sizeof(tBTA_GATTC_NOTIF_REG));
658 p_clreg->notif_reg[i].in_use = TRUE;
659 memcpy(p_clreg->notif_reg[i].remote_bda, bda, BD_ADDR_LEN);
661 p_clreg->notif_reg[i].char_id.srvc_id.is_primary = p_char_id->srvc_id.is_primary;
662 bta_gattc_cpygattid(&p_clreg->notif_reg[i].char_id.srvc_id.id, &p_char_id->srvc_id.id);
663 bta_gattc_cpygattid(&p_clreg->notif_reg[i].char_id.char_id, &p_char_id->char_id);
665 status = BTA_GATT_OK;
669 if (i == BTA_GATTC_NOTIF_REG_MAX)
671 status = BTA_GATT_NO_RESOURCES;
672 APPL_TRACE_ERROR("Max Notification Reached, registration failed.");
678 APPL_TRACE_ERROR("Client_if: %d Not Registered", client_if);
684 /*******************************************************************************
686 ** Function BTA_GATTC_DeregisterForNotifications
688 ** Description This function is called to de-register for notification of a service.
690 ** Parameters client_if - client interface.
691 ** bda - target GATT server.
692 ** p_char_id - pointer to GATT characteristic ID.
694 ** Returns OK if deregistration succeed, otherwise failed.
696 *******************************************************************************/
697 tBTA_GATT_STATUS BTA_GATTC_DeregisterForNotifications (tBTA_GATTC_IF client_if,
699 tBTA_GATTC_CHAR_ID *p_char_id)
701 tBTA_GATTC_RCB *p_clreg;
702 tBTA_GATT_STATUS status = BTA_GATT_ILLEGAL_PARAMETER;
707 APPL_TRACE_ERROR("%s deregistration failed, unknown char id", __func__);
711 if ((p_clreg = bta_gattc_cl_get_regcb(client_if)) != NULL)
713 for (i = 0; i < BTA_GATTC_NOTIF_REG_MAX; i ++)
715 if (p_clreg->notif_reg[i].in_use &&
716 !memcmp(p_clreg->notif_reg[i].remote_bda, bda, BD_ADDR_LEN) &&
717 bta_gattc_charid_compare(&p_clreg->notif_reg[i].char_id, p_char_id))
719 APPL_TRACE_DEBUG("%s deregistered bd_addr:%02x:%02x:%02x:%02x:%02x:%02x",
720 __func__, bda[0], bda[1], bda[2], bda[3], bda[4], bda[5]);
721 memset(&p_clreg->notif_reg[i], 0, sizeof(tBTA_GATTC_NOTIF_REG));
722 status = BTA_GATT_OK;
726 if (i == BTA_GATTC_NOTIF_REG_MAX)
728 status = BTA_GATT_ERROR;
729 APPL_TRACE_ERROR("%s registration not found bd_addr:%02x:%02x:%02x:%02x:%02x:%02x",
730 __func__, bda[0], bda[1], bda[2], bda[3], bda[4], bda[5]);
735 APPL_TRACE_ERROR("%s client_if: %d not registered bd_addr:%02x:%02x:%02x:%02x:%02x:%02x",
736 __func__, client_if, bda[0], bda[1], bda[2], bda[3], bda[4], bda[5]);
742 /*******************************************************************************
744 ** Function BTA_GATTC_Refresh
746 ** Description Refresh the server cache of the remote device
748 ** Parameters remote_bda: remote device BD address.
752 *******************************************************************************/
753 void BTA_GATTC_Refresh(BD_ADDR remote_bda)
755 tBTA_GATTC_API_OPEN *p_buf =
756 (tBTA_GATTC_API_OPEN *)osi_malloc(sizeof(tBTA_GATTC_API_OPEN));
758 p_buf->hdr.event = BTA_GATTC_API_REFRESH_EVT;
759 memcpy(p_buf->remote_bda, remote_bda, BD_ADDR_LEN);
761 bta_sys_sendmsg(p_buf);
764 /*******************************************************************************
766 ** Function BTA_GATTC_Listen
768 ** Description Start advertisement to listen for connection request for a GATT
769 ** client application.
771 ** Parameters client_if: server interface.
772 ** start: to start or stop listening for connection
773 ** remote_bda: remote device BD address, if listen to all device
778 *******************************************************************************/
779 void BTA_GATTC_Listen(tBTA_GATTC_IF client_if, BOOLEAN start, BD_ADDR_PTR target_bda)
781 tBTA_GATTC_API_LISTEN *p_buf =
782 (tBTA_GATTC_API_LISTEN *)osi_malloc(sizeof(tBTA_GATTC_API_LISTEN) + BD_ADDR_LEN);
784 p_buf->hdr.event = BTA_GATTC_API_LISTEN_EVT;
785 p_buf->client_if = client_if;
786 p_buf->start = start;
788 p_buf->remote_bda = (UINT8*)(p_buf + 1);
789 memcpy(p_buf->remote_bda, target_bda, BD_ADDR_LEN);
791 p_buf->remote_bda = NULL;
794 bta_sys_sendmsg(p_buf);
797 /*******************************************************************************
799 ** Function BTA_GATTC_Broadcast
801 ** Description Start broadcasting (non-connectable advertisements)
803 ** Parameters client_if: client interface.
804 ** start: to start or stop listening for connection
808 *******************************************************************************/
809 void BTA_GATTC_Broadcast(tBTA_GATTC_IF client_if, BOOLEAN start)
811 tBTA_GATTC_API_LISTEN *p_buf =
812 (tBTA_GATTC_API_LISTEN *)osi_malloc(sizeof(tBTA_GATTC_API_LISTEN) + BD_ADDR_LEN);
814 p_buf->hdr.event = BTA_GATTC_API_BROADCAST_EVT;
815 p_buf->client_if = client_if;
816 p_buf->start = start;
818 bta_sys_sendmsg(p_buf);
821 #endif /* BTA_GATT_INCLUDED */