1/****************************************************************************** 2 * 3 * Copyright (C) 2003-2012 Broadcom Corporation 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 file contains the GATT client main functions and state machine. 22 * 23 ******************************************************************************/ 24 25#include "bt_target.h" 26 27#if defined(BTA_GATT_INCLUDED) && (BTA_GATT_INCLUDED == TRUE) 28 29#include <string.h> 30 31#include "bta_gattc_int.h" 32#include "gki.h" 33 34 35/***************************************************************************** 36** Constants and types 37*****************************************************************************/ 38 39 40/* state machine action enumeration list */ 41enum 42{ 43 BTA_GATTC_OPEN, 44 BTA_GATTC_OPEN_FAIL, 45 BTA_GATTC_OPEN_ERROR, 46 BTA_GATTC_CANCEL_OPEN, 47 BTA_GATTC_CANCEL_OPEN_OK, 48 BTA_GATTC_CANCEL_OPEN_ERROR, 49 BTA_GATTC_CONN, 50 BTA_GATTC_START_DISCOVER, 51 BTA_GATTC_DISC_CMPL, 52 53 BTA_GATTC_Q_CMD, 54 BTA_GATTC_CLOSE, 55 BTA_GATTC_CLOSE_FAIL, 56 BTA_GATTC_READ, 57 BTA_GATTC_WRITE, 58 59 BTA_GATTC_OP_CMPL, 60 BTA_GATTC_SEARCH, 61 BTA_GATTC_FAIL, 62 BTA_GATTC_CONFIRM, 63 BTA_GATTC_EXEC, 64 BTA_GATTC_READ_MULTI, 65 BTA_GATTC_CI_OPEN, 66 BTA_GATTC_CI_LOAD, 67 BTA_GATTC_CI_SAVE, 68 BTA_GATTC_CACHE_OPEN, 69 BTA_GATTC_IGNORE_OP_CMPL, 70 BTA_GATTC_DISC_CLOSE, 71 BTA_GATTC_RESTART_DISCOVER, 72 BTA_GATTC_CFG_MTU, 73 74 BTA_GATTC_IGNORE 75}; 76/* type for action functions */ 77typedef void (*tBTA_GATTC_ACTION)(tBTA_GATTC_CLCB *p_clcb, tBTA_GATTC_DATA *p_data); 78 79/* action function list */ 80const tBTA_GATTC_ACTION bta_gattc_action[] = 81{ 82 bta_gattc_open, 83 bta_gattc_open_fail, 84 bta_gattc_open_error, 85 bta_gattc_cancel_open, 86 bta_gattc_cancel_open_ok, 87 bta_gattc_cancel_open_error, 88 bta_gattc_conn, 89 bta_gattc_start_discover, 90 bta_gattc_disc_cmpl, 91 92 bta_gattc_q_cmd, 93 bta_gattc_close, 94 bta_gattc_close_fail, 95 bta_gattc_read, 96 bta_gattc_write, 97 98 bta_gattc_op_cmpl, 99 bta_gattc_search, 100 bta_gattc_fail, 101 bta_gattc_confirm, 102 bta_gattc_execute, 103 bta_gattc_read_multi, 104 bta_gattc_ci_open, 105 bta_gattc_ci_load, 106 bta_gattc_ci_save, 107 bta_gattc_cache_open, 108 bta_gattc_ignore_op_cmpl, 109 bta_gattc_disc_close, 110 bta_gattc_restart_discover, 111 bta_gattc_cfg_mtu 112}; 113 114 115/* state table information */ 116#define BTA_GATTC_ACTIONS 1 /* number of actions */ 117#define BTA_GATTC_NEXT_STATE 1 /* position of next state */ 118#define BTA_GATTC_NUM_COLS 2 /* number of columns in state tables */ 119 120/* state table for idle state */ 121static const UINT8 bta_gattc_st_idle[][BTA_GATTC_NUM_COLS] = 122{ 123/* Event Action 1 Next state */ 124/* BTA_GATTC_API_OPEN_EVT */ {BTA_GATTC_OPEN, BTA_GATTC_W4_CONN_ST}, 125/* BTA_GATTC_INT_OPEN_FAIL_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_IDLE_ST}, 126/* BTA_GATTC_API_CANCEL_OPEN_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_IDLE_ST}, 127/* BTA_GATTC_INT_CANCEL_OPEN_OK_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_IDLE_ST}, 128 129/* BTA_GATTC_API_READ_EVT */ {BTA_GATTC_FAIL, BTA_GATTC_IDLE_ST}, 130/* BTA_GATTC_API_WRITE_EVT */ {BTA_GATTC_FAIL, BTA_GATTC_IDLE_ST}, 131/* BTA_GATTC_API_EXEC_EVT */ {BTA_GATTC_FAIL, BTA_GATTC_IDLE_ST}, 132/* BTA_GATTC_API_CFG_MTU_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_IDLE_ST}, 133 134/* BTA_GATTC_API_CLOSE_EVT */ {BTA_GATTC_CLOSE_FAIL, BTA_GATTC_IDLE_ST}, 135 136/* BTA_GATTC_API_SEARCH_EVT */ {BTA_GATTC_FAIL, BTA_GATTC_IDLE_ST}, 137/* BTA_GATTC_API_CONFIRM_EVT */ {BTA_GATTC_FAIL, BTA_GATTC_IDLE_ST}, 138/* BTA_GATTC_API_READ_MULTI_EVT */ {BTA_GATTC_FAIL, BTA_GATTC_IDLE_ST}, 139/* BTA_GATTC_API_REFRESH_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_IDLE_ST}, 140 141/* BTA_GATTC_INT_CONN_EVT */ {BTA_GATTC_CONN, BTA_GATTC_CONN_ST}, 142/* BTA_GATTC_INT_DISCOVER_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_IDLE_ST}, 143/* BTA_GATTC_DISCOVER_CMPL_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_IDLE_ST}, 144/* BTA_GATTC_OP_CMPL_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_IDLE_ST}, 145/* BTA_GATTC_INT_DISCONN_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_IDLE_ST}, 146 147 148/* ===> for cache loading, saving */ 149/* BTA_GATTC_START_CACHE_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_IDLE_ST}, 150/* BTA_GATTC_CI_CACHE_OPEN_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_IDLE_ST}, 151/* BTA_GATTC_CI_CACHE_LOAD_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_IDLE_ST}, 152/* BTA_GATTC_CI_CACHE_SAVE_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_IDLE_ST} 153}; 154 155/* state table for wait for open state */ 156static const UINT8 bta_gattc_st_w4_conn[][BTA_GATTC_NUM_COLS] = 157{ 158/* Event Action 1 Next state */ 159/* BTA_GATTC_API_OPEN_EVT */ {BTA_GATTC_OPEN, BTA_GATTC_W4_CONN_ST}, 160/* BTA_GATTC_INT_OPEN_FAIL_EVT */ {BTA_GATTC_OPEN_FAIL, BTA_GATTC_IDLE_ST}, 161/* BTA_GATTC_API_CANCEL_OPEN_EVT */ {BTA_GATTC_CANCEL_OPEN, BTA_GATTC_W4_CONN_ST}, 162/* BTA_GATTC_INT_CANCEL_OPEN_OK_EVT */ {BTA_GATTC_CANCEL_OPEN_OK, BTA_GATTC_IDLE_ST}, 163 164/* BTA_GATTC_API_READ_EVT */ {BTA_GATTC_FAIL, BTA_GATTC_W4_CONN_ST}, 165/* BTA_GATTC_API_WRITE_EVT */ {BTA_GATTC_FAIL, BTA_GATTC_W4_CONN_ST}, 166/* BTA_GATTC_API_EXEC_EVT */ {BTA_GATTC_FAIL, BTA_GATTC_W4_CONN_ST}, 167/* BTA_GATTC_API_CFG_MTU_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_W4_CONN_ST}, 168 169/* BTA_GATTC_API_CLOSE_EVT */ {BTA_GATTC_CANCEL_OPEN, BTA_GATTC_W4_CONN_ST}, 170 171/* BTA_GATTC_API_SEARCH_EVT */ {BTA_GATTC_FAIL, BTA_GATTC_W4_CONN_ST}, 172/* BTA_GATTC_API_CONFIRM_EVT */ {BTA_GATTC_FAIL, BTA_GATTC_W4_CONN_ST}, 173/* BTA_GATTC_API_READ_MULTI_EVT */ {BTA_GATTC_FAIL, BTA_GATTC_W4_CONN_ST}, 174/* BTA_GATTC_API_REFRESH_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_W4_CONN_ST}, 175 176/* BTA_GATTC_INT_CONN_EVT */ {BTA_GATTC_CONN, BTA_GATTC_CONN_ST}, 177/* BTA_GATTC_INT_DISCOVER_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_W4_CONN_ST}, 178/* BTA_GATTC_DISCOVER_CMPL_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_W4_CONN_ST}, 179/* BTA_GATTC_OP_CMPL_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_W4_CONN_ST}, 180/* BTA_GATTC_INT_DISCONN_EVT */ {BTA_GATTC_OPEN_FAIL, BTA_GATTC_IDLE_ST}, 181 182/* ===> for cache loading, saving */ 183/* BTA_GATTC_START_CACHE_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_W4_CONN_ST}, 184/* BTA_GATTC_CI_CACHE_OPEN_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_W4_CONN_ST}, 185/* BTA_GATTC_CI_CACHE_LOAD_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_W4_CONN_ST}, 186/* BTA_GATTC_CI_CACHE_SAVE_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_W4_CONN_ST} 187}; 188 189/* state table for open state */ 190static const UINT8 bta_gattc_st_connected[][BTA_GATTC_NUM_COLS] = 191{ 192/* Event Action 1 Next state */ 193/* BTA_GATTC_API_OPEN_EVT */ {BTA_GATTC_OPEN, BTA_GATTC_CONN_ST}, 194/* BTA_GATTC_INT_OPEN_FAIL_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_CONN_ST}, 195/* BTA_GATTC_API_CANCEL_OPEN_EVT */ {BTA_GATTC_CANCEL_OPEN_ERROR, BTA_GATTC_CONN_ST}, 196/* BTA_GATTC_INT_CANCEL_OPEN_OK_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_CONN_ST}, 197 198/* BTA_GATTC_API_READ_EVT */ {BTA_GATTC_READ, BTA_GATTC_CONN_ST}, 199/* BTA_GATTC_API_WRITE_EVT */ {BTA_GATTC_WRITE, BTA_GATTC_CONN_ST}, 200/* BTA_GATTC_API_EXEC_EVT */ {BTA_GATTC_EXEC, BTA_GATTC_CONN_ST}, 201/* BTA_GATTC_API_CFG_MTU_EVT */ {BTA_GATTC_CFG_MTU, BTA_GATTC_CONN_ST}, 202 203/* BTA_GATTC_API_CLOSE_EVT */ {BTA_GATTC_CLOSE, BTA_GATTC_IDLE_ST}, 204 205/* BTA_GATTC_API_SEARCH_EVT */ {BTA_GATTC_SEARCH, BTA_GATTC_CONN_ST}, 206/* BTA_GATTC_API_CONFIRM_EVT */ {BTA_GATTC_CONFIRM, BTA_GATTC_CONN_ST}, 207/* BTA_GATTC_API_READ_MULTI_EVT */ {BTA_GATTC_READ_MULTI, BTA_GATTC_CONN_ST}, 208/* BTA_GATTC_API_REFRESH_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_CONN_ST}, 209 210/* BTA_GATTC_INT_CONN_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_CONN_ST}, 211/* BTA_GATTC_INT_DISCOVER_EVT */ {BTA_GATTC_START_DISCOVER, BTA_GATTC_DISCOVER_ST}, 212/* BTA_GATTC_DISCOVER_CMPL_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_CONN_ST}, 213/* BTA_GATTC_OP_CMPL_EVT */ {BTA_GATTC_OP_CMPL, BTA_GATTC_CONN_ST}, 214 215/* BTA_GATTC_INT_DISCONN_EVT */ {BTA_GATTC_CLOSE, BTA_GATTC_IDLE_ST}, 216 217/* ===> for cache loading, saving */ 218/* BTA_GATTC_START_CACHE_EVT */ {BTA_GATTC_CACHE_OPEN, BTA_GATTC_DISCOVER_ST}, 219/* BTA_GATTC_CI_CACHE_OPEN_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_CONN_ST}, 220/* BTA_GATTC_CI_CACHE_LOAD_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_CONN_ST}, 221/* BTA_GATTC_CI_CACHE_SAVE_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_CONN_ST} 222}; 223 224/* state table for discover state */ 225static const UINT8 bta_gattc_st_discover[][BTA_GATTC_NUM_COLS] = 226{ 227/* Event Action 1 Next state */ 228/* BTA_GATTC_API_OPEN_EVT */ {BTA_GATTC_OPEN, BTA_GATTC_DISCOVER_ST}, 229/* BTA_GATTC_INT_OPEN_FAIL_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_DISCOVER_ST}, 230/* BTA_GATTC_API_CANCEL_OPEN_EVT */ {BTA_GATTC_CANCEL_OPEN_ERROR, BTA_GATTC_DISCOVER_ST}, 231/* BTA_GATTC_INT_CANCEL_OPEN_OK_EVT */ {BTA_GATTC_FAIL, BTA_GATTC_DISCOVER_ST}, 232 233/* BTA_GATTC_API_READ_EVT */ {BTA_GATTC_Q_CMD, BTA_GATTC_DISCOVER_ST}, 234/* BTA_GATTC_API_WRITE_EVT */ {BTA_GATTC_Q_CMD, BTA_GATTC_DISCOVER_ST}, 235/* BTA_GATTC_API_EXEC_EVT */ {BTA_GATTC_Q_CMD, BTA_GATTC_DISCOVER_ST}, 236/* BTA_GATTC_API_CFG_MTU_EVT */ {BTA_GATTC_Q_CMD, BTA_GATTC_DISCOVER_ST}, 237 238/* BTA_GATTC_API_CLOSE_EVT */ {BTA_GATTC_DISC_CLOSE, BTA_GATTC_DISCOVER_ST}, 239 240/* BTA_GATTC_API_SEARCH_EVT */ {BTA_GATTC_Q_CMD, BTA_GATTC_DISCOVER_ST}, 241/* BTA_GATTC_API_CONFIRM_EVT */ {BTA_GATTC_CONFIRM, BTA_GATTC_DISCOVER_ST}, 242/* BTA_GATTC_API_READ_MULTI_EVT */ {BTA_GATTC_Q_CMD, BTA_GATTC_DISCOVER_ST}, 243/* BTA_GATTC_API_REFRESH_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_DISCOVER_ST}, 244 245/* BTA_GATTC_INT_CONN_EVT */ {BTA_GATTC_CONN, BTA_GATTC_DISCOVER_ST}, 246/* BTA_GATTC_INT_DISCOVER_EVT */ {BTA_GATTC_RESTART_DISCOVER, BTA_GATTC_DISCOVER_ST}, 247/* BTA_GATTC_DISCOVER_CMPL_EVT */ {BTA_GATTC_DISC_CMPL, BTA_GATTC_CONN_ST}, 248/* BTA_GATTC_OP_CMPL_EVT */ {BTA_GATTC_IGNORE_OP_CMPL, BTA_GATTC_DISCOVER_ST}, 249/* BTA_GATTC_INT_DISCONN_EVT */ {BTA_GATTC_CLOSE, BTA_GATTC_IDLE_ST}, 250 251/* ===> for cache loading, saving */ 252/* BTA_GATTC_START_CACHE_EVT */ {BTA_GATTC_IGNORE, BTA_GATTC_DISCOVER_ST}, 253/* BTA_GATTC_CI_CACHE_OPEN_EVT */ {BTA_GATTC_CI_OPEN, BTA_GATTC_DISCOVER_ST}, 254/* BTA_GATTC_CI_CACHE_LOAD_EVT */ {BTA_GATTC_CI_LOAD, BTA_GATTC_DISCOVER_ST}, 255/* BTA_GATTC_CI_CACHE_SAVE_EVT */ {BTA_GATTC_CI_SAVE, BTA_GATTC_DISCOVER_ST} 256}; 257 258/* type for state table */ 259typedef const UINT8 (*tBTA_GATTC_ST_TBL)[BTA_GATTC_NUM_COLS]; 260 261/* state table */ 262const tBTA_GATTC_ST_TBL bta_gattc_st_tbl[] = 263{ 264 bta_gattc_st_idle, 265 bta_gattc_st_w4_conn, 266 bta_gattc_st_connected, 267 bta_gattc_st_discover 268}; 269 270/***************************************************************************** 271** Global data 272*****************************************************************************/ 273 274/* GATTC control block */ 275#if BTA_DYNAMIC_MEMORY == FALSE 276tBTA_GATTC_CB bta_gattc_cb; 277#endif 278 279#if BTA_GATT_DEBUG == TRUE 280static char *gattc_evt_code(tBTA_GATTC_INT_EVT evt_code); 281static char *gattc_state_code(tBTA_GATTC_STATE state_code); 282#endif 283 284/******************************************************************************* 285** 286** Function bta_gattc_sm_execute 287** 288** Description State machine event handling function for GATTC 289** 290** 291** Returns BOOLEAN : TRUE if queued client request buffer can be immediately released 292** else FALSE 293** 294*******************************************************************************/ 295BOOLEAN bta_gattc_sm_execute(tBTA_GATTC_CLCB *p_clcb, UINT16 event, tBTA_GATTC_DATA *p_data) 296{ 297 tBTA_GATTC_ST_TBL state_table; 298 UINT8 action; 299 int i; 300 BOOLEAN rt = TRUE; 301#if BTA_GATT_DEBUG == TRUE 302 tBTA_GATTC_STATE in_state = p_clcb->state; 303 UINT16 in_event = event; 304 APPL_TRACE_DEBUG("bta_gattc_sm_execute: State 0x%02x [%s], Event 0x%x[%s]", in_state, 305 gattc_state_code(in_state), 306 in_event, 307 gattc_evt_code(in_event)); 308#endif 309 310 311 /* look up the state table for the current state */ 312 state_table = bta_gattc_st_tbl[p_clcb->state]; 313 314 event &= 0x00FF; 315 316 /* set next state */ 317 p_clcb->state = state_table[event][BTA_GATTC_NEXT_STATE]; 318 319 /* execute action functions */ 320 for (i = 0; i < BTA_GATTC_ACTIONS; i++) 321 { 322 if ((action = state_table[event][i]) != BTA_GATTC_IGNORE) 323 { 324 (*bta_gattc_action[action])(p_clcb, p_data); 325 if (p_clcb->p_q_cmd == p_data) { 326 /* buffer is queued, don't free in the bta dispatcher. 327 * we free it ourselves when a completion event is received. 328 */ 329 rt = FALSE; 330 } 331 } 332 else 333 { 334 break; 335 } 336 } 337 338#if BTA_GATT_DEBUG == TRUE 339 if (in_state != p_clcb->state) 340 { 341 APPL_TRACE_DEBUG("GATTC State Change: [%s] -> [%s] after Event [%s]", 342 gattc_state_code(in_state), 343 gattc_state_code(p_clcb->state), 344 gattc_evt_code(in_event)); 345 } 346#endif 347 return rt; 348} 349 350/******************************************************************************* 351** 352** Function bta_gattc_hdl_event 353** 354** Description GATT client main event handling function. 355** 356** 357** Returns BOOLEAN 358** 359*******************************************************************************/ 360BOOLEAN bta_gattc_hdl_event(BT_HDR *p_msg) 361{ 362 tBTA_GATTC_CB *p_cb = &bta_gattc_cb; 363 tBTA_GATTC_CLCB *p_clcb = NULL; 364 tBTA_GATTC_RCB *p_clreg; 365 BOOLEAN rt = TRUE; 366#if BTA_GATT_DEBUG == TRUE 367 APPL_TRACE_DEBUG("bta_gattc_hdl_event: Event [%s]", gattc_evt_code(p_msg->event)); 368#endif 369 switch (p_msg->event) 370 { 371 case BTA_GATTC_API_DISABLE_EVT: 372 bta_gattc_disable(p_cb); 373 break; 374 375 case BTA_GATTC_API_REG_EVT: 376 bta_gattc_register(p_cb, (tBTA_GATTC_DATA *) p_msg); 377 break; 378 379 case BTA_GATTC_INT_START_IF_EVT: 380 bta_gattc_start_if(p_cb, (tBTA_GATTC_DATA *) p_msg); 381 break; 382 383 case BTA_GATTC_API_DEREG_EVT: 384 p_clreg = bta_gattc_cl_get_regcb(((tBTA_GATTC_DATA *)p_msg)->api_dereg.client_if); 385 bta_gattc_deregister(p_cb, p_clreg); 386 break; 387 388 case BTA_GATTC_API_OPEN_EVT: 389 bta_gattc_process_api_open(p_cb, (tBTA_GATTC_DATA *) p_msg); 390 break; 391 392 case BTA_GATTC_API_CANCEL_OPEN_EVT: 393 bta_gattc_process_api_open_cancel(p_cb, (tBTA_GATTC_DATA *) p_msg); 394 break; 395 396 case BTA_GATTC_API_REFRESH_EVT: 397 bta_gattc_process_api_refresh(p_cb, (tBTA_GATTC_DATA *) p_msg); 398 break; 399 400#if BLE_INCLUDED == TRUE 401 case BTA_GATTC_API_LISTEN_EVT: 402 bta_gattc_listen(p_cb, (tBTA_GATTC_DATA *) p_msg); 403 break; 404 case BTA_GATTC_API_BROADCAST_EVT: 405 bta_gattc_broadcast(p_cb, (tBTA_GATTC_DATA *) p_msg); 406 break; 407#endif 408 409 case BTA_GATTC_ENC_CMPL_EVT: 410 bta_gattc_process_enc_cmpl(p_cb, (tBTA_GATTC_DATA *) p_msg); 411 break; 412 413 default: 414 if (p_msg->event == BTA_GATTC_INT_CONN_EVT) 415 p_clcb = bta_gattc_find_int_conn_clcb((tBTA_GATTC_DATA *) p_msg); 416 else if (p_msg->event == BTA_GATTC_INT_DISCONN_EVT) 417 p_clcb = bta_gattc_find_int_disconn_clcb((tBTA_GATTC_DATA *) p_msg); 418 else 419 p_clcb = bta_gattc_find_clcb_by_conn_id(p_msg->layer_specific); 420 421 if (p_clcb != NULL) 422 { 423 rt = bta_gattc_sm_execute(p_clcb, p_msg->event, (tBTA_GATTC_DATA *) p_msg); 424 } 425 else 426 { 427 APPL_TRACE_DEBUG("Ignore unknown conn ID: %d", p_msg->layer_specific); 428 } 429 430 break; 431 } 432 433 434 return rt; 435} 436 437 438/***************************************************************************** 439** Debug Functions 440*****************************************************************************/ 441#if BTA_GATT_DEBUG == TRUE 442 443/******************************************************************************* 444** 445** Function gattc_evt_code 446** 447** Description 448** 449** Returns void 450** 451*******************************************************************************/ 452static char *gattc_evt_code(tBTA_GATTC_INT_EVT evt_code) 453{ 454 switch (evt_code) 455 { 456 case BTA_GATTC_API_OPEN_EVT: 457 return "BTA_GATTC_API_OPEN_EVT"; 458 case BTA_GATTC_INT_OPEN_FAIL_EVT: 459 return "BTA_GATTC_INT_OPEN_FAIL_EVT"; 460 case BTA_GATTC_API_CANCEL_OPEN_EVT: 461 return "BTA_GATTC_API_CANCEL_OPEN_EVT"; 462 case BTA_GATTC_INT_CANCEL_OPEN_OK_EVT: 463 return "BTA_GATTC_INT_CANCEL_OPEN_OK_EVT"; 464 case BTA_GATTC_API_READ_EVT: 465 return "BTA_GATTC_API_READ_EVT"; 466 case BTA_GATTC_API_WRITE_EVT: 467 return "BTA_GATTC_API_WRITE_EVT"; 468 case BTA_GATTC_API_EXEC_EVT: 469 return "BTA_GATTC_API_EXEC_EVT"; 470 case BTA_GATTC_API_CLOSE_EVT: 471 return "BTA_GATTC_API_CLOSE_EVT"; 472 case BTA_GATTC_API_SEARCH_EVT: 473 return "BTA_GATTC_API_SEARCH_EVT"; 474 case BTA_GATTC_API_CONFIRM_EVT: 475 return "BTA_GATTC_API_CONFIRM_EVT"; 476 case BTA_GATTC_API_READ_MULTI_EVT: 477 return "BTA_GATTC_API_READ_MULTI_EVT"; 478 case BTA_GATTC_INT_CONN_EVT: 479 return "BTA_GATTC_INT_CONN_EVT"; 480 case BTA_GATTC_INT_DISCOVER_EVT: 481 return "BTA_GATTC_INT_DISCOVER_EVT"; 482 case BTA_GATTC_DISCOVER_CMPL_EVT: 483 return "BTA_GATTC_DISCOVER_CMPL_EVT"; 484 case BTA_GATTC_OP_CMPL_EVT: 485 return "BTA_GATTC_OP_CMPL_EVT"; 486 case BTA_GATTC_INT_DISCONN_EVT: 487 return "BTA_GATTC_INT_DISCONN_EVT"; 488 case BTA_GATTC_START_CACHE_EVT: 489 return "BTA_GATTC_START_CACHE_EVT"; 490 case BTA_GATTC_CI_CACHE_OPEN_EVT: 491 return "BTA_GATTC_CI_CACHE_OPEN_EVT"; 492 case BTA_GATTC_CI_CACHE_LOAD_EVT: 493 return "BTA_GATTC_CI_CACHE_LOAD_EVT"; 494 case BTA_GATTC_CI_CACHE_SAVE_EVT: 495 return "BTA_GATTC_CI_CACHE_SAVE_EVT"; 496 case BTA_GATTC_INT_START_IF_EVT: 497 return "BTA_GATTC_INT_START_IF_EVT"; 498 case BTA_GATTC_API_REG_EVT: 499 return "BTA_GATTC_API_REG_EVT"; 500 case BTA_GATTC_API_DEREG_EVT: 501 return "BTA_GATTC_API_DEREG_EVT"; 502 case BTA_GATTC_API_REFRESH_EVT: 503 return "BTA_GATTC_API_REFRESH_EVT"; 504 case BTA_GATTC_API_LISTEN_EVT: 505 return "BTA_GATTC_API_LISTEN_EVT"; 506 case BTA_GATTC_API_DISABLE_EVT: 507 return "BTA_GATTC_API_DISABLE_EVT"; 508 case BTA_GATTC_API_CFG_MTU_EVT: 509 return "BTA_GATTC_API_CFG_MTU_EVT"; 510 default: 511 return "unknown GATTC event code"; 512 } 513} 514 515/******************************************************************************* 516** 517** Function gattc_state_code 518** 519** Description 520** 521** Returns void 522** 523*******************************************************************************/ 524static char *gattc_state_code(tBTA_GATTC_STATE state_code) 525{ 526 switch (state_code) 527 { 528 case BTA_GATTC_IDLE_ST: 529 return "GATTC_IDLE_ST"; 530 case BTA_GATTC_W4_CONN_ST: 531 return "GATTC_W4_CONN_ST"; 532 case BTA_GATTC_CONN_ST: 533 return "GATTC_CONN_ST"; 534 case BTA_GATTC_DISCOVER_ST: 535 return "GATTC_DISCOVER_ST"; 536 default: 537 return "unknown GATTC state code"; 538 } 539} 540 541#endif /* Debug Functions */ 542#endif /* BTA_GATT_INCLUDED */ 543