Home | History | Annotate | Download | only in include
      1 /******************************************************************************
      2  *
      3  *  Copyright (C) 1999-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 #ifndef GATT_API_H
     19 #define GATT_API_H
     20 
     21 #include "bt_target.h"
     22 #include "gattdefs.h"
     23 
     24 /*****************************************************************************
     25 **  Constants
     26 *****************************************************************************/
     27 /* Success code and error codes */
     28 #define  GATT_SUCCESS                        0x0000
     29 #define  GATT_INVALID_HANDLE                 0x0001
     30 #define  GATT_READ_NOT_PERMIT                0x0002
     31 #define  GATT_WRITE_NOT_PERMIT               0x0003
     32 #define  GATT_INVALID_PDU                    0x0004
     33 #define  GATT_INSUF_AUTHENTICATION           0x0005
     34 #define  GATT_REQ_NOT_SUPPORTED              0x0006
     35 #define  GATT_INVALID_OFFSET                 0x0007
     36 #define  GATT_INSUF_AUTHORIZATION            0x0008
     37 #define  GATT_PREPARE_Q_FULL                 0x0009
     38 #define  GATT_NOT_FOUND                      0x000a
     39 #define  GATT_NOT_LONG                       0x000b
     40 #define  GATT_INSUF_KEY_SIZE                 0x000c
     41 #define  GATT_INVALID_ATTR_LEN               0x000d
     42 #define  GATT_ERR_UNLIKELY                   0x000e
     43 #define  GATT_INSUF_ENCRYPTION               0x000f
     44 #define  GATT_UNSUPPORT_GRP_TYPE             0x0010
     45 #define  GATT_INSUF_RESOURCE                 0x0011
     46 
     47 
     48 #define  GATT_ILLEGAL_PARAMETER              0x0087
     49 #define  GATT_NO_RESOURCES                   0x0080
     50 #define  GATT_INTERNAL_ERROR                 0x0081
     51 #define  GATT_WRONG_STATE                    0x0082
     52 #define  GATT_DB_FULL                        0x0083
     53 #define  GATT_BUSY                           0x0084
     54 #define  GATT_ERROR                          0x0085
     55 #define  GATT_CMD_STARTED                    0x0086
     56 #define  GATT_PENDING                        0x0088
     57 #define  GATT_AUTH_FAIL                      0x0089
     58 #define  GATT_MORE                           0x008a
     59 #define  GATT_INVALID_CFG                    0x008b
     60 #define  GATT_SERVICE_STARTED                0x008c
     61 #define  GATT_ENCRYPED_MITM                  GATT_SUCCESS
     62 #define  GATT_ENCRYPED_NO_MITM               0x008d
     63 #define  GATT_NOT_ENCRYPTED                  0x008e
     64 
     65 
     66 typedef UINT8 tGATT_STATUS;
     67 
     68 
     69 #define  GATT_RSP_ERROR                      0x01
     70 #define  GATT_REQ_MTU                        0x02
     71 #define  GATT_RSP_MTU                        0x03
     72 #define  GATT_REQ_FIND_INFO                  0x04
     73 #define  GATT_RSP_FIND_INFO                  0x05
     74 #define  GATT_REQ_FIND_TYPE_VALUE            0x06
     75 #define  GATT_RSP_FIND_TYPE_VALUE            0x07
     76 #define  GATT_REQ_READ_BY_TYPE               0x08
     77 #define  GATT_RSP_READ_BY_TYPE               0x09
     78 #define  GATT_REQ_READ                       0x0A
     79 #define  GATT_RSP_READ                       0x0B
     80 #define  GATT_REQ_READ_BLOB                  0x0C
     81 #define  GATT_RSP_READ_BLOB                  0x0D
     82 #define  GATT_REQ_READ_MULTI                 0x0E
     83 #define  GATT_RSP_READ_MULTI                 0x0F
     84 #define  GATT_REQ_READ_BY_GRP_TYPE           0x10
     85 #define  GATT_RSP_READ_BY_GRP_TYPE           0x11
     86 #define  GATT_REQ_WRITE                      0x12 /*                 0001-0010 (write)*/
     87 #define  GATT_RSP_WRITE                      0x13
     88 #define  GATT_CMD_WRITE                      0x52 /* changed in V4.0 01001-0010(write cmd)*/
     89 #define  GATT_REQ_PREPARE_WRITE              0x16
     90 #define  GATT_RSP_PREPARE_WRITE              0x17
     91 #define  GATT_REQ_EXEC_WRITE                 0x18
     92 #define  GATT_RSP_EXEC_WRITE                 0x19
     93 #define  GATT_HANDLE_VALUE_NOTIF             0x1B
     94 #define  GATT_HANDLE_VALUE_IND               0x1D
     95 #define  GATT_HANDLE_VALUE_CONF              0x1E
     96 #define  GATT_SIGN_CMD_WRITE                 0xD2 /* changed in V4.0 1101-0010 (signed write)  see write cmd above*/
     97 #define  GATT_OP_CODE_MAX                    GATT_HANDLE_VALUE_CONF + 1 /* 0x1E = 30 + 1 = 31*/
     98 
     99 
    100 #define  GATT_HANDLE_IS_VALID(x) ((x) != 0)
    101 
    102 #define GATT_CONN_UNKNOWN                   0
    103 #define GATT_CONN_NO_RESOURCES              L2CAP_CONN_NO_RESOURCES         /* connection fail for l2cap resource failure */
    104 #define GATT_CONN_TIMEOUT                   HCI_ERR_CONNECTION_TOUT         /* 0x08 connection timeout  */
    105 #define GATT_CONN_TERMINATE_PEER_USER       HCI_ERR_PEER_USER               /* 0x13 connection terminate by peer user  */
    106 #define GATT_CONN_TERMINATE_LOCAL_HOST      HCI_ERR_CONN_CAUSE_LOCAL_HOST   /* 0x16 connectionterminated by local host  */
    107 #define GATT_CONN_FAIL_ESTABLISH            HCI_ERR_CONN_FAILED_ESTABLISHMENT/* 0x03E connection fail to establish  */
    108 #define GATT_CONN_LMP_TIMEOUT               HCI_ERR_LMP_RESPONSE_TIMEOUT     /* 0x22 connection fail for LMP response tout */
    109 #define GATT_CONN_CANCEL                    L2CAP_CONN_CANCEL                /* 0x0100 L2CAP connection cancelled  */
    110 typedef UINT16 tGATT_DISCONN_REASON;
    111 
    112 /* MAX GATT MTU size
    113 */
    114 #ifndef GATT_MAX_MTU_SIZE
    115     #define GATT_MAX_MTU_SIZE     517
    116 #endif
    117 
    118 /* max legth of an attribute value
    119 */
    120 #ifndef GATT_MAX_ATTR_LEN
    121     #define GATT_MAX_ATTR_LEN     600
    122 #endif
    123 
    124 /* default GATT MTU size over LE link
    125 */
    126 #define GATT_DEF_BLE_MTU_SIZE       23
    127 
    128 /* invalid connection ID
    129 */
    130 #define GATT_INVALID_CONN_ID        0xFFFF
    131 
    132 #ifndef GATT_CL_MAX_LCB
    133     #define GATT_CL_MAX_LCB     22
    134 #endif
    135 
    136 #ifndef GATT_MAX_SCCB
    137     #define GATT_MAX_SCCB       10
    138 #endif
    139 
    140 
    141 
    142 /* GATT notification caching timer, default to be three seconds
    143 */
    144 #ifndef GATTC_NOTIF_TIMEOUT
    145     #define GATTC_NOTIF_TIMEOUT   3
    146 #endif
    147 
    148 /*****************************************************************************
    149 ** GATT Structure Definition
    150 *****************************************************************************/
    151 
    152 /* Attribute permissions
    153 */
    154 #define GATT_PERM_READ              (1 << 0) /* bit 0 */
    155 #define GATT_PERM_READ_ENCRYPTED    (1 << 1) /* bit 1 */
    156 #define GATT_PERM_READ_ENC_MITM     (1 << 2) /* bit 2 */
    157 #define GATT_PERM_WRITE             (1 << 4) /* bit 4 */
    158 #define GATT_PERM_WRITE_ENCRYPTED   (1 << 5) /* bit 5 */
    159 #define GATT_PERM_WRITE_ENC_MITM    (1 << 6) /* bit 6 */
    160 #define GATT_PERM_WRITE_SIGNED      (1 << 7) /* bit 7 */
    161 #define GATT_PERM_WRITE_SIGNED_MITM (1 << 8) /* bit 8 */
    162 typedef UINT16 tGATT_PERM;
    163 
    164 #define GATT_ENCRYPT_KEY_SIZE_MASK  (0xF000) /* the MS nibble of tGATT_PERM; key size 7=0; size 16=9 */
    165 
    166 #define GATT_READ_ALLOWED           (GATT_PERM_READ | GATT_PERM_READ_ENCRYPTED | GATT_PERM_READ_ENC_MITM)
    167 #define GATT_READ_AUTH_REQUIRED     (GATT_PERM_READ_ENC_MITM)
    168 #define GATT_READ_MITM_REQUIRED     (GATT_PERM_READ_ENC_MITM)
    169 #define GATT_READ_ENCRYPTED_REQUIRED   (GATT_PERM_READ_ENCRYPTED | GATT_PERM_READ_ENC_MITM)
    170 
    171 
    172 #define GATT_WRITE_ALLOWED          (GATT_PERM_WRITE | GATT_PERM_WRITE_ENCRYPTED | GATT_PERM_WRITE_ENC_MITM | \
    173                                      GATT_PERM_WRITE_SIGNED | GATT_PERM_WRITE_SIGNED_MITM)
    174 
    175 #define GATT_WRITE_AUTH_REQUIRED    (GATT_PERM_WRITE_ENCRYPTED | GATT_PERM_WRITE_SIGNED)
    176 
    177 #define GATT_WRITE_MITM_REQUIRED    (GATT_PERM_WRITE_ENC_MITM | GATT_PERM_WRITE_SIGNED_MITM)
    178 
    179 #define GATT_WRITE_ENCRYPTED_PERM   (GATT_PERM_WRITE_ENCRYPTED | GATT_PERM_WRITE_ENC_MITM)
    180 
    181 #define GATT_WRITE_SIGNED_PERM      (GATT_PERM_WRITE_SIGNED | GATT_PERM_WRITE_SIGNED_MITM)
    182 
    183 
    184 /* Characteristic properties
    185 */
    186 #define GATT_CHAR_PROP_BIT_BROADCAST    (1 << 0)
    187 #define GATT_CHAR_PROP_BIT_READ         (1 << 1)
    188 #define GATT_CHAR_PROP_BIT_WRITE_NR     (1 << 2)
    189 #define GATT_CHAR_PROP_BIT_WRITE        (1 << 3)
    190 #define GATT_CHAR_PROP_BIT_NOTIFY       (1 << 4)
    191 #define GATT_CHAR_PROP_BIT_INDICATE     (1 << 5)
    192 #define GATT_CHAR_PROP_BIT_AUTH         (1 << 6)
    193 #define GATT_CHAR_PROP_BIT_EXT_PROP     (1 << 7)
    194 typedef UINT8 tGATT_CHAR_PROP;
    195 
    196 
    197 /* Format of the value of a characteristic. enumeration type
    198 */
    199 enum
    200 {
    201     GATT_FORMAT_RES,            /* rfu */
    202     GATT_FORMAT_BOOL,           /* 0x01 boolean */
    203     GATT_FORMAT_2BITS,           /* 0x02 2 bit */
    204     GATT_FORMAT_NIBBLE,         /* 0x03 nibble */
    205     GATT_FORMAT_UINT8,          /* 0x04 uint8 */
    206     GATT_FORMAT_UINT12,         /* 0x05 uint12 */
    207     GATT_FORMAT_UINT16,         /* 0x06 uint16 */
    208     GATT_FORMAT_UINT24,         /* 0x07 uint24 */
    209     GATT_FORMAT_UINT32,         /* 0x08 uint32 */
    210     GATT_FORMAT_UINT48,         /* 0x09 uint48 */
    211     GATT_FORMAT_UINT64,         /* 0x0a uint64 */
    212     GATT_FORMAT_UINT128,        /* 0x0B uint128 */
    213     GATT_FORMAT_SINT8,          /* 0x0C signed 8 bit integer */
    214     GATT_FORMAT_SINT12,         /* 0x0D signed 12 bit integer */
    215     GATT_FORMAT_SINT16,         /* 0x0E signed 16 bit integer */
    216     GATT_FORMAT_SINT24,         /* 0x0F signed 24 bit integer */
    217     GATT_FORMAT_SINT32,         /* 0x10 signed 32 bit integer */
    218     GATT_FORMAT_SINT48,         /* 0x11 signed 48 bit integer */
    219     GATT_FORMAT_SINT64,         /* 0x12 signed 64 bit integer */
    220     GATT_FORMAT_SINT128,        /* 0x13 signed 128 bit integer */
    221     GATT_FORMAT_FLOAT32,        /* 0x14 float 32 */
    222     GATT_FORMAT_FLOAT64,        /* 0x15 float 64*/
    223     GATT_FORMAT_SFLOAT,         /* 0x16 IEEE-11073 16 bit SFLOAT */
    224     GATT_FORMAT_FLOAT,          /* 0x17 IEEE-11073 32 bit SFLOAT */
    225     GATT_FORMAT_DUINT16,        /* 0x18 IEEE-20601 format */
    226     GATT_FORMAT_UTF8S,          /* 0x19 UTF-8 string */
    227     GATT_FORMAT_UTF16S,         /* 0x1a UTF-16 string */
    228     GATT_FORMAT_STRUCT,         /* 0x1b Opaque structure*/
    229     GATT_FORMAT_MAX             /* 0x1c or above reserved */
    230 };
    231 typedef UINT8 tGATT_FORMAT;
    232 
    233 /* Characteristic Presentation Format Descriptor value
    234 */
    235 typedef struct
    236 {
    237     UINT16              unit;       /* as UUIUD defined by SIG */
    238     UINT16              descr;       /* as UUID as defined by SIG */
    239     tGATT_FORMAT        format;
    240     INT8                exp;
    241     UINT8               name_spc;   /* The name space of the description */
    242 } tGATT_CHAR_PRES;
    243 
    244 #define GATT_VALID_RANGE_MAX_SIZE       16
    245 typedef struct
    246 {
    247     UINT8                   format;
    248     UINT16                  len;
    249     UINT8                   lower_range[GATT_VALID_RANGE_MAX_SIZE]; /* in little endian format */
    250     UINT8                   upper_range[GATT_VALID_RANGE_MAX_SIZE];
    251 } tGATT_VALID_RANGE;
    252 
    253 /* Characteristic Aggregate Format attribute value
    254 */
    255 #define GATT_AGGR_HANDLE_NUM_MAX        10
    256 typedef struct
    257 {
    258     UINT8                   num_handle;
    259     UINT16                  handle_list[GATT_AGGR_HANDLE_NUM_MAX];
    260 } tGATT_CHAR_AGGRE;
    261 
    262 /* Characteristic descriptor: Extended Properties value
    263 */
    264 #define GATT_CHAR_BIT_REL_WRITE    0x0001       /* permits reliable writes of the Characteristic Value */
    265 #define GATT_CHAR_BIT_WRITE_AUX    0x0002       /* permits writes to the characteristic descriptor */
    266 
    267 
    268 /* characteristic descriptor: client configuration value
    269 */
    270 #define GATT_CLT_CONFIG_NONE               0x0000
    271 #define GATT_CLT_CONFIG_NOTIFICATION       0x0001
    272 #define GATT_CLT_CONFIG_INDICATION         0x0002
    273 typedef UINT16 tGATT_CLT_CHAR_CONFIG;
    274 
    275 
    276 /* characteristic descriptor: server configuration value
    277 */
    278 #define GATT_SVR_CONFIG_NONE                     0x0000
    279 #define GATT_SVR_CONFIG_BROADCAST                0x0001
    280 typedef UINT16 tGATT_SVR_CHAR_CONFIG;
    281 
    282 /* Characteristic descriptor: Extended Properties value
    283 */
    284 #define GATT_CHAR_BIT_REL_WRITE    0x0001       /* permits reliable writes of the Characteristic Value */
    285 #define GATT_CHAR_BIT_WRITE_AUX    0x0002       /* permits writes to the characteristic descriptor */
    286 
    287 /* authentication requirement
    288 */
    289 #define GATT_AUTH_REQ_NONE              0
    290 #define GATT_AUTH_REQ_NO_MITM           1   /* unauthenticated encryption */
    291 #define GATT_AUTH_REQ_MITM              2   /* authenticated encryption */
    292 #define GATT_AUTH_REQ_SIGNED_NO_MITM    3
    293 #define GATT_AUTH_REQ_SIGNED_MITM       4
    294 typedef UINT8 tGATT_AUTH_REQ;
    295 
    296 /* Attribute Value structure
    297 */
    298 typedef struct
    299 {
    300     UINT16          conn_id;
    301     UINT16          handle;     /* attribute handle */
    302     UINT16          offset;     /* attribute value offset, if no offfset is needed for the command, ignore it */
    303     UINT16          len;        /* length of attribute value */
    304     tGATT_AUTH_REQ  auth_req;   /*  authentication request */
    305     UINT8           value[GATT_MAX_ATTR_LEN];  /* the actual attribute value */
    306 } tGATT_VALUE;
    307 
    308 /* Union of the event data which is used in the server respond API to carry the server response information
    309 */
    310 typedef union
    311 {
    312     /* data type            member          event   */
    313     tGATT_VALUE             attr_value;     /* READ, HANDLE_VALUE_IND, PREPARE_WRITE */
    314                                             /* READ_BLOB, READ_BY_TYPE */
    315     UINT16                  handle;         /* WRITE, WRITE_BLOB */
    316 
    317 } tGATTS_RSP;
    318 
    319 /* Transports for the primary service  */
    320 enum
    321 {
    322     GATT_TRANSPORT_LE,
    323     GATT_TRANSPORT_BR_EDR,
    324     GATT_TRANSPORT_LE_BR_EDR
    325 };
    326 typedef UINT8 tGATT_TRANSPORT;
    327 
    328 #define GATT_PREP_WRITE_CANCEL   0x00
    329 #define GATT_PREP_WRITE_EXEC     0x01
    330 typedef UINT8   tGATT_EXEC_FLAG;
    331 
    332 /* read request always based on UUID */
    333 typedef struct
    334 {
    335     UINT16        handle;
    336     UINT16        offset;
    337     BOOLEAN       is_long;
    338 } tGATT_READ_REQ;
    339 
    340 /* write request data */
    341 typedef struct
    342 {
    343     UINT16          handle;     /* attribute handle */
    344     UINT16          offset;     /* attribute value offset, if no offfset is needed for the command, ignore it */
    345     UINT16          len;        /* length of attribute value */
    346     UINT8           value[GATT_MAX_ATTR_LEN];  /* the actual attribute value */
    347     BOOLEAN         need_rsp;   /* need write response */
    348     BOOLEAN         is_prep;    /* is prepare write */
    349 } tGATT_WRITE_REQ;
    350 
    351 /* callback data for server access request from client */
    352 typedef union
    353 {
    354     tGATT_READ_REQ         read_req;       /* read request, read by Type, read blob */
    355 
    356     tGATT_WRITE_REQ        write_req;    /* write */
    357                                          /* prepare write */
    358                                          /* write blob */
    359     UINT16                 handle;       /* handle value confirmation */
    360     UINT16                 mtu;          /* MTU exchange request */
    361     tGATT_EXEC_FLAG        exec_write;    /* execute write */
    362 } tGATTS_DATA;
    363 
    364 typedef UINT8 tGATT_SERV_IF;               /* GATT Service Interface */
    365 
    366 enum
    367 {
    368     GATTS_REQ_TYPE_READ = 1,        /* Attribute read request */
    369     GATTS_REQ_TYPE_WRITE,           /* Attribute write request */
    370     GATTS_REQ_TYPE_WRITE_EXEC,      /* Execute write */
    371     GATTS_REQ_TYPE_MTU,             /* MTU exchange information */
    372     GATTS_REQ_TYPE_CONF             /* handle value confirmation */
    373 };
    374 typedef UINT8   tGATTS_REQ_TYPE;
    375 
    376 
    377 
    378 /* Client Used Data Structure
    379 */
    380 /* definition of different discovery types */
    381 enum
    382 {
    383     GATT_DISC_SRVC_ALL = 1,     /* discover all services */
    384     GATT_DISC_SRVC_BY_UUID,     /* discover service of a special type */
    385     GATT_DISC_INC_SRVC,         /* discover the included service within a service */
    386     GATT_DISC_CHAR,             /* discover characteristics of a service with/without type requirement */
    387     GATT_DISC_CHAR_DSCPT,       /* discover characteristic descriptors of a character */
    388     GATT_DISC_MAX               /* maximnun discover type */
    389 };
    390 typedef UINT8   tGATT_DISC_TYPE;
    391 
    392 /* Discover parameters of different discovery types
    393 */
    394 typedef struct
    395 {
    396     tBT_UUID    service;
    397     UINT16      s_handle;
    398     UINT16      e_handle;
    399 }tGATT_DISC_PARAM;
    400 
    401 /* GATT read type enumeration
    402 */
    403 enum
    404 {
    405     GATT_READ_BY_TYPE =        1,
    406     GATT_READ_BY_HANDLE,
    407     GATT_READ_MULTIPLE,
    408     GATT_READ_CHAR_VALUE,
    409     GATT_READ_PARTIAL,
    410     GATT_READ_MAX
    411 };
    412 typedef UINT8 tGATT_READ_TYPE;
    413 
    414 /* Read By Type Request (GATT_READ_BY_TYPE) Data
    415 */
    416 typedef struct
    417 {
    418     tGATT_AUTH_REQ      auth_req;
    419     UINT16              s_handle;
    420     UINT16              e_handle;
    421     tBT_UUID            uuid;
    422 } tGATT_READ_BY_TYPE;
    423 
    424 /*   GATT_READ_MULTIPLE request data
    425 */
    426 #define GATT_MAX_READ_MULTI_HANDLES      10           /* Max attributes to read in one request */
    427 typedef struct
    428 {
    429     tGATT_AUTH_REQ          auth_req;
    430     UINT16                  num_handles;                            /* number of handles to read */
    431     UINT16                  handles[GATT_MAX_READ_MULTI_HANDLES];   /* handles list to be read */
    432 } tGATT_READ_MULTI;
    433 
    434 /*   Read By Handle Request (GATT_READ_BY_HANDLE) data */
    435 typedef struct
    436 {
    437     tGATT_AUTH_REQ         auth_req;
    438     UINT16                 handle;
    439 } tGATT_READ_BY_HANDLE;
    440 
    441 /*   READ_BT_HANDLE_Request data */
    442 typedef struct
    443 {
    444     tGATT_AUTH_REQ         auth_req;
    445     UINT16                 handle;
    446     UINT16                 offset;
    447 } tGATT_READ_PARTIAL;
    448 
    449 /* Read Request Data
    450 */
    451 typedef union
    452 {
    453     tGATT_READ_BY_TYPE   service;
    454     tGATT_READ_BY_TYPE   char_type;        /* characterisitc type */
    455     tGATT_READ_MULTI     read_multiple;
    456     tGATT_READ_BY_HANDLE by_handle;
    457     tGATT_READ_PARTIAL   partial;
    458 } tGATT_READ_PARAM;
    459 
    460 /* GATT write type enumeration */
    461 enum
    462 {
    463     GATT_WRITE_NO_RSP = 1,
    464     GATT_WRITE ,
    465     GATT_WRITE_PREPARE
    466 };
    467 typedef UINT8 tGATT_WRITE_TYPE;
    468 
    469 /* Client Operation Complete Callback Data
    470 */
    471 typedef union
    472 {
    473     tGATT_VALUE          att_value;
    474     UINT16               mtu;
    475     UINT16               handle;
    476 } tGATT_CL_COMPLETE;
    477 
    478 /* GATT client operation type, used in client callback function
    479 */
    480 #define GATTC_OPTYPE_NONE                 0
    481 #define GATTC_OPTYPE_DISCOVERY            1
    482 #define GATTC_OPTYPE_READ                 2
    483 #define GATTC_OPTYPE_WRITE                3
    484 #define GATTC_OPTYPE_EXE_WRITE            4
    485 #define GATTC_OPTYPE_CONFIG               5
    486 #define GATTC_OPTYPE_NOTIFICATION         6
    487 #define GATTC_OPTYPE_INDICATION           7
    488 typedef UINT8 tGATTC_OPTYPE;
    489 
    490 /* characteristic declaration
    491 */
    492 typedef struct
    493 {
    494     tGATT_CHAR_PROP       char_prop;   /* characterisitc properties */
    495     UINT16                val_handle;  /* characteristic value attribute handle */
    496     tBT_UUID              char_uuid;   /* characteristic UUID type */
    497 } tGATT_CHAR_DCLR_VAL;
    498 
    499 /* primary service group data
    500 */
    501 typedef struct
    502 {
    503     UINT16          e_handle;       /* ending handle of the group */
    504     tBT_UUID        service_type;   /* group type */
    505 } tGATT_GROUP_VALUE;
    506 
    507 
    508 /* included service attribute value
    509 */
    510 typedef struct
    511 {
    512     tBT_UUID    service_type;       /* included service UUID */
    513     UINT16      s_handle;           /* starting handle */
    514     UINT16      e_handle;           /* ending handle */
    515 } tGATT_INCL_SRVC;
    516 
    517 typedef union
    518 {
    519     tGATT_INCL_SRVC     incl_service;  /* include service value */
    520     tGATT_GROUP_VALUE   group_value;   /* Service UUID type.
    521                                           This field is used with GATT_DISC_SRVC_ALL
    522                                           type of discovery result callback. */
    523 
    524     UINT16              handle;        /* When used with GATT_DISC_SRVC_BY_UUID type
    525                                           discovery result, it is the ending handle of a
    526                                           known service to be discovered. When used with
    527                                           GATT_DISC_INC_SRVC type discovery result,
    528                                           it is the included service starting handle.*/
    529 
    530     tGATT_CHAR_DCLR_VAL dclr_value;    /* Characteristic declaration value.
    531                                           This field is used with GATT_DISC_CHAR type discovery.*/
    532 } tGATT_DISC_VALUE;
    533 
    534 /* discover result record
    535 */
    536 typedef struct
    537 {
    538     tBT_UUID            type;
    539     UINT16              handle;
    540     tGATT_DISC_VALUE    value;
    541 } tGATT_DISC_RES;
    542 
    543 
    544 typedef UINT8 tGATT_IF;
    545 #define GATT_LINK_IDLE_TIMEOUT_WHEN_NO_APP    0 /* start a idle timer for this duration when no application
    546                                               need to use the link */
    547 
    548 #define GATT_LINK_NO_IDLE_TIMEOUT            0xFFFF
    549 
    550 #define GATT_INVALID_ACL_HANDLE              0xFFFF
    551 /* discover result callback function */
    552 typedef void (tGATT_DISC_RES_CB) (UINT16 conn_id, tGATT_DISC_TYPE disc_type, tGATT_DISC_RES *p_data);
    553 
    554 /* discover complete callback function */
    555 typedef void (tGATT_DISC_CMPL_CB) (UINT16 conn_id, tGATT_DISC_TYPE disc_type, tGATT_STATUS status);
    556 
    557 /* Define a callback function for when read/write/disc/config operation is completed. */
    558 typedef void (tGATT_CMPL_CBACK) (UINT16 conn_id, tGATTC_OPTYPE op, tGATT_STATUS status, tGATT_CL_COMPLETE *p_data);
    559 
    560 /* Define a callback function when an initialized connection is established. */
    561 typedef void (tGATT_CONN_CBACK) (tGATT_IF gatt_if, BD_ADDR bda, UINT16 conn_id, BOOLEAN connected, tGATT_DISCONN_REASON reason);
    562 
    563 /* attribute request callback for ATT server */
    564 typedef void  (tGATT_REQ_CBACK )(UINT16 conn_id, UINT32 trans_id, tGATTS_REQ_TYPE type, tGATTS_DATA *p_data);
    565 
    566 
    567 
    568 
    569 /* Define the structure that applications use to register with
    570 ** GATT. This structure includes callback functions. All functions
    571 ** MUST be provided.
    572 */
    573 typedef struct
    574 {
    575     tGATT_CONN_CBACK                *p_conn_cb;
    576     tGATT_CMPL_CBACK                *p_cmpl_cb;
    577     tGATT_DISC_RES_CB               *p_disc_res_cb;
    578     tGATT_DISC_CMPL_CB              *p_disc_cmpl_cb;
    579     tGATT_REQ_CBACK                 *p_req_cb;
    580 } tGATT_CBACK;
    581 
    582 /***********************  Start Handle Management Definitions   **********************
    583 */
    584 
    585 
    586 typedef struct
    587 {
    588     tBT_UUID app_uuid128;
    589     tBT_UUID svc_uuid;
    590     UINT16   svc_inst;
    591     UINT16   s_handle;
    592     UINT16   e_handle;
    593     BOOLEAN  is_primary;      /* primary service or secondary */
    594 } tGATTS_HNDL_RANGE;
    595 
    596 
    597 
    598 #define GATTS_SRV_CHG_CMD_ADD_CLIENT       1
    599 #define GATTS_SRV_CHG_CMD_UPDATE_CLIENT    2
    600 #define GATTS_SRV_CHG_CMD_REMOVE_CLIENT    3
    601 #define GATTS_SRV_CHG_CMD_READ_NUM_CLENTS  4
    602 #define GATTS_SRV_CHG_CMD_READ_CLENT       5
    603 typedef UINT8 tGATTS_SRV_CHG_CMD;
    604 
    605 typedef struct
    606 {
    607     BD_ADDR         bda;
    608     BOOLEAN         srv_changed;
    609 } tGATTS_SRV_CHG;
    610 
    611 
    612 typedef union
    613 {
    614     tGATTS_SRV_CHG  srv_chg;
    615     UINT8           client_read_index; /* only used for sequential reading client srv chg info */
    616 } tGATTS_SRV_CHG_REQ;
    617 
    618 typedef union
    619 {
    620     tGATTS_SRV_CHG srv_chg;
    621     UINT8 num_clients;
    622 } tGATTS_SRV_CHG_RSP;
    623 
    624 
    625 
    626 typedef struct
    627 {
    628     tGATTS_HNDL_RANGE   *p_new_srv_start;
    629 } tGATTS_PENDING_NEW_SRV_START;
    630 
    631 /* Attibute server handle ranges NV storage callback functions
    632 */
    633 typedef void  (tGATTS_NV_SAVE_CBACK)(BOOLEAN is_saved, tGATTS_HNDL_RANGE *p_hndl_range);
    634 typedef BOOLEAN  (tGATTS_NV_SRV_CHG_CBACK)(tGATTS_SRV_CHG_CMD cmd, tGATTS_SRV_CHG_REQ *p_req, tGATTS_SRV_CHG_RSP *p_rsp);
    635 
    636 typedef struct
    637 {
    638     tGATTS_NV_SAVE_CBACK       *p_nv_save_callback;
    639     tGATTS_NV_SRV_CHG_CBACK    *p_srv_chg_callback;
    640 } tGATT_APPL_INFO;
    641 
    642 /*
    643 ***********************  End Handle Management Definitions   **********************/
    644 
    645 /*****************************************************************************
    646 **  External Function Declarations
    647 *****************************************************************************/
    648 #ifdef __cplusplus
    649 extern "C"
    650 {
    651 #endif
    652 
    653 /*******************************************************************************
    654 **
    655 ** Function         GATT_SetTraceLevel
    656 **
    657 ** Description      This function sets the trace level.  If called with
    658 **                  a value of 0xFF, it simply returns the current trace level.
    659 **
    660 ** Returns          The new or current trace level
    661 **
    662 *******************************************************************************/
    663     GATT_API extern UINT8 GATT_SetTraceLevel (UINT8 new_level);
    664 
    665 
    666 /*******************************************************************************/
    667 /* GATT Profile API Functions */
    668 /*******************************************************************************/
    669 /* GATT Profile Server Functions */
    670 /*******************************************************************************/
    671 /*******************************************************************************
    672 **
    673 ** Function         GATTS_AddHandleRange
    674 **
    675 ** Description      This function add the allocated handles range for the specifed
    676 **                  application UUID, service UUID and service instance
    677 **
    678 ** Parameter        p_hndl_range:   pointer to allocated handles information
    679 **
    680 ** Returns          TRUE if handle range is added sucessfully; otherwise FALSE.
    681 **
    682 *******************************************************************************/
    683 
    684     GATT_API extern BOOLEAN GATTS_AddHandleRange(tGATTS_HNDL_RANGE *p_hndl_range);
    685 
    686 /*******************************************************************************
    687 **
    688 ** Function         GATTS_NVRegister
    689 **
    690 ** Description      Application manager calls this function to register for
    691 **                  NV save callback function.  There can be one and only one
    692 **                  NV save callback function.
    693 **
    694 ** Parameter        p_cb_info : callback informaiton
    695 **
    696 ** Returns          TRUE if registered OK, else FALSE
    697 **
    698 *******************************************************************************/
    699     GATT_API extern BOOLEAN  GATTS_NVRegister (tGATT_APPL_INFO *p_cb_info);
    700 
    701 
    702 /*******************************************************************************
    703 **
    704 ** Function         GATTS_CreateService
    705 **
    706 ** Description      This function is called to reserve a block of handles for a service.
    707 **
    708 **                  *** It should be called only once per service instance  ***
    709 **
    710 ** Parameter        gatt_if       : application if
    711 **                  p_svc_uuid    : service UUID
    712 **                  svc_inst      : instance of the service inside the application
    713 **                  num_handles   : number of handles needed by the service.
    714 **                  is_pri        : is a primary service or not.
    715 **
    716 ** Returns          service handle if sucessful, otherwise 0.
    717 **
    718 *******************************************************************************/
    719     GATT_API extern UINT16 GATTS_CreateService (tGATT_IF gatt_if, tBT_UUID *p_svc_uuid,
    720                                                 UINT16 svc_inst, UINT16 num_handles, BOOLEAN is_pri);
    721 
    722 
    723 /*******************************************************************************
    724 **
    725 ** Function         GATTS_AddIncludeService
    726 **
    727 ** Description      This function is called to add an included service.
    728 **
    729 ** Parameter        service_handle : To which service this included service is added to.
    730 **                  include_svc_handle    : included service handle.
    731 **
    732 ** Returns          included service attribute handle. If 0, add included service
    733 **                  fail.
    734 **
    735 *******************************************************************************/
    736     GATT_API extern UINT16 GATTS_AddIncludeService (UINT16 service_handle,
    737                                                     UINT16 include_svc_handle);
    738 
    739 
    740 /*******************************************************************************
    741 **
    742 ** Function         GATTS_AddCharacteristic
    743 **
    744 ** Description      This function is called to add a characteristic into a service.
    745 **                  It will add a characteristic declaration and characteristic
    746 **                  value declaration into the service database identified by the
    747 **                  service handle.
    748 **
    749 ** Parameter        service_handle : To which service this included service is added to.
    750 **                  char_uuid : Characteristic UUID.
    751 **                  perm      : Characteristic value declaration attribute permission.
    752 **                  property  : Characteristic Properties
    753 **
    754 ** Returns          Characteristic value declaration attribute handle. 0 if add
    755 **                  characteristic failed.
    756 **
    757 *******************************************************************************/
    758     GATT_API extern UINT16 GATTS_AddCharacteristic (UINT16 service_handle, tBT_UUID *char_uuid,
    759                                                     tGATT_PERM perm,tGATT_CHAR_PROP property);
    760 
    761 /*******************************************************************************
    762 **
    763 ** Function         GATTS_AddCharDescriptor
    764 **
    765 ** Description      This function is called to add a characteristic descriptor
    766 **                  into a service database. Add descriptor should follow add char
    767 **                  to which it belongs, and next add char should be done only
    768 **                  after all add descriptors for the previous char.
    769 **
    770 ** Parameter        service_handle  : To which service this characteristic descriptor
    771 **                                    is added to.
    772 **                  perm            : Characteristic value declaration attribute
    773 **                                    permission.
    774 **                  p_descr_uuid    : Characteristic descriptor UUID.
    775 **
    776 ** Returns         Characteristic descriptor attribute handle. 0 if add
    777 **                 characteristic descriptor failed.
    778 **
    779 *******************************************************************************/
    780     GATT_API extern UINT16 GATTS_AddCharDescriptor (UINT16 service_handle, tGATT_PERM perm,
    781                                                      tBT_UUID * p_descr_uuid);
    782 
    783 /*******************************************************************************
    784 **
    785 ** Function         GATTS_DeleteService
    786 **
    787 ** Description      This function is called to delete a service.
    788 **
    789 ** Parameter        gatt_if       : application interface
    790 **                  p_svc_uuid    : service UUID
    791 **                  svc_inst      : instance of the service inside the application
    792 **
    793 ** Returns          TRUE if operation succeed, FALSE if handle block was not found.
    794 **
    795 *******************************************************************************/
    796     GATT_API extern BOOLEAN GATTS_DeleteService (tGATT_IF gatt_if, tBT_UUID *p_svc_uuid, UINT16 svc_inst);
    797 
    798 /*******************************************************************************
    799 **
    800 ** Function         GATTS_StartService
    801 **
    802 ** Description      This function is called to start a service with GATT
    803 **
    804 ** Parameter        gatt_if : service handle.
    805 **                  p_cback       : application service callback functions.
    806 **                  sup_transport : supported transport(s) for this primary service
    807 **
    808 ** return           GATT_SUCCESS if sucessfully started; otherwise error code.
    809 **
    810 *******************************************************************************/
    811     GATT_API extern tGATT_STATUS GATTS_StartService (tGATT_IF gatt_if, UINT16 service_handle,
    812                                                      tGATT_TRANSPORT sup_transport);
    813 
    814 
    815 /*******************************************************************************
    816 **
    817 ** Function         GATTS_StopService
    818 **
    819 ** Description      This function is called to stop a service
    820 **
    821 ** Parameter         service_handle : this is the start handle of a service
    822 **
    823 ** Returns          None.
    824 **
    825 *******************************************************************************/
    826     GATT_API extern void GATTS_StopService (UINT16 service_handle);
    827 
    828 
    829 /*******************************************************************************
    830 **
    831 ** Function         GATTs_HandleValueIndication
    832 **
    833 ** Description      This function sends a handle value indication to a client.
    834 **
    835 ** Parameter        conn_id: connection identifier.
    836 **                  attr_handle: Attribute handle of this handle value indication.
    837 **                  val_len: Length of the indicated attribute value.
    838 **                  p_val: Pointer to the indicated attribute value data.
    839 **
    840 ** Returns          GATT_SUCCESS if sucessfully sent or queued; otherwise error code.
    841 **
    842 *******************************************************************************/
    843     GATT_API extern  tGATT_STATUS GATTS_HandleValueIndication (UINT16 conn_id,
    844                                                                UINT16 attr_handle,
    845                                                                UINT16 val_len, UINT8 *p_val);
    846 
    847 /*******************************************************************************
    848 **
    849 ** Function         GATTS_HandleValueNotification
    850 **
    851 ** Description      This function sends a handle value notification to a client.
    852 **
    853 ** Parameter       conn_id: connection identifier.
    854 **                  attr_handle: Attribute handle of this handle value indication.
    855 **                  val_len: Length of the indicated attribute value.
    856 **                  p_val: Pointer to the indicated attribute value data.
    857 **
    858 ** Returns          GATT_SUCCESS if sucessfully sent; otherwise error code.
    859 **
    860 *******************************************************************************/
    861     GATT_API extern  tGATT_STATUS GATTS_HandleValueNotification (UINT16 conn_id, UINT16 attr_handle,
    862                                                                  UINT16 val_len, UINT8 *p_val);
    863 
    864 
    865 /*******************************************************************************
    866 **
    867 ** Function         GATTS_SendRsp
    868 **
    869 ** Description      This function sends the server response to client.
    870 **
    871 ** Parameter        conn_id: connection identifier.
    872 **                  trans_id: transaction id
    873 **                  status: response status
    874 **                  p_msg: pointer to message parameters structure.
    875 **
    876 ** Returns          GATT_SUCCESS if sucessfully sent; otherwise error code.
    877 **
    878 *******************************************************************************/
    879     GATT_API extern  tGATT_STATUS GATTS_SendRsp (UINT16 conn_id,  UINT32 trans_id,
    880                                                  tGATT_STATUS status, tGATTS_RSP *p_msg);
    881 
    882 
    883 /*******************************************************************************/
    884 /* GATT Profile Client Functions */
    885 /*******************************************************************************/
    886 
    887 /*******************************************************************************
    888 **
    889 ** Function         GATTC_ConfigureMTU
    890 **
    891 ** Description      This function is called to configure the ATT MTU size for
    892 **                  a connection on an LE transport.
    893 **
    894 ** Parameters       conn_id: connection identifier.
    895 **                  mtu    - attribute MTU size..
    896 **
    897 ** Returns          GATT_SUCCESS if command started successfully.
    898 **
    899 *******************************************************************************/
    900     GATT_API extern tGATT_STATUS GATTC_ConfigureMTU (UINT16 conn_id, UINT16  mtu);
    901 
    902 /*******************************************************************************
    903 **
    904 ** Function         GATTC_Discover
    905 **
    906 ** Description      This function is called to do a discovery procedure on ATT server.
    907 **
    908 ** Parameters       conn_id: connection identifier.
    909 **                  disc_type:discovery type.
    910 **                  p_param: parameters of discovery requirement.
    911 **
    912 ** Returns          GATT_SUCCESS if command received/sent successfully.
    913 **
    914 *******************************************************************************/
    915     GATT_API extern tGATT_STATUS GATTC_Discover (UINT16 conn_id,
    916                                                  tGATT_DISC_TYPE disc_type,
    917                                                  tGATT_DISC_PARAM *p_param );
    918 /*******************************************************************************
    919 **
    920 ** Function         GATTC_Read
    921 **
    922 ** Description      This function is called to read the value of an attribute from
    923 **                  the server.
    924 **
    925 ** Parameters       conn_id: connection identifier.
    926 **                  type    - attribute read type.
    927 **                  p_read  - read operation parameters.
    928 **
    929 ** Returns          GATT_SUCCESS if command started successfully.
    930 **
    931 *******************************************************************************/
    932     GATT_API extern tGATT_STATUS GATTC_Read (UINT16 conn_id, tGATT_READ_TYPE type,
    933                                              tGATT_READ_PARAM *p_read);
    934 
    935 /*******************************************************************************
    936 **
    937 ** Function         GATTC_Write
    938 **
    939 ** Description      This function is called to read the value of an attribute from
    940 **                  the server.
    941 **
    942 ** Parameters       conn_id: connection identifier.
    943 **                  type    - attribute write type.
    944 **                  p_write  - write operation parameters.
    945 **
    946 ** Returns          GATT_SUCCESS if command started successfully.
    947 **
    948 *******************************************************************************/
    949     GATT_API extern tGATT_STATUS GATTC_Write (UINT16 conn_id, tGATT_WRITE_TYPE type,
    950                                               tGATT_VALUE *p_write);
    951 
    952 
    953 /*******************************************************************************
    954 **
    955 ** Function         GATTC_ExecuteWrite
    956 **
    957 ** Description      This function is called to send an Execute write request to
    958 **                  the server.
    959 **
    960 ** Parameters       conn_id: connection identifier.
    961 **                  is_execute - to execute or cancel the prepare write requet(s)
    962 **
    963 ** Returns          GATT_SUCCESS if command started successfully.
    964 **
    965 *******************************************************************************/
    966     GATT_API extern tGATT_STATUS GATTC_ExecuteWrite (UINT16 conn_id, BOOLEAN is_execute);
    967 
    968 /*******************************************************************************
    969 **
    970 ** Function         GATTC_SendHandleValueConfirm
    971 **
    972 ** Description      This function is called to send a handle value confirmation
    973 **                  as response to a handle value notification from server.
    974 **
    975 ** Parameters       conn_id: connection identifier.
    976 **                  handle: the handle of the attribute confirmation.
    977 **
    978 ** Returns          GATT_SUCCESS if command started successfully.
    979 **
    980 *******************************************************************************/
    981     GATT_API extern tGATT_STATUS GATTC_SendHandleValueConfirm (UINT16 conn_id, UINT16 handle);
    982 
    983 
    984 /*******************************************************************************
    985 **
    986 ** Function         GATT_SetIdleTimeout
    987 **
    988 ** Description      This function (common to both client and server) sets the idle
    989 **                  timeout for a tansport connection
    990 **
    991 ** Parameter        bd_addr:   target device bd address.
    992 **                  idle_tout: timeout value in seconds.
    993 **
    994 ** Returns          void
    995 **
    996 *******************************************************************************/
    997     GATT_API extern void GATT_SetIdleTimeout (BD_ADDR bd_addr, UINT16 idle_tout);
    998 
    999 
   1000 /*******************************************************************************
   1001 **
   1002 ** Function         GATT_Register
   1003 **
   1004 ** Description      This function is called to register an  application
   1005 **                  with GATT
   1006 **
   1007 ** Parameter        p_app_uuid128: Application UUID
   1008 **                  p_cb_info: callback functions.
   1009 **
   1010 ** Returns          0 for error, otherwise the index of the client registered with GATT
   1011 **
   1012 *******************************************************************************/
   1013     GATT_API extern  tGATT_IF GATT_Register (tBT_UUID *p_app_uuid128, tGATT_CBACK *p_cb_info);
   1014 
   1015 /*******************************************************************************
   1016 **
   1017 ** Function         GATT_Deregister
   1018 **
   1019 ** Description      This function deregistered the application from GATT.
   1020 **
   1021 ** Parameters       gatt_if: applicaiton interface.
   1022 **
   1023 ** Returns          None.
   1024 **
   1025 *******************************************************************************/
   1026     GATT_API extern void GATT_Deregister (tGATT_IF gatt_if);
   1027 
   1028 /*******************************************************************************
   1029 **
   1030 ** Function         GATT_StartIf
   1031 **
   1032 ** Description      This function is called after registration to start receiving
   1033 **                  callbacks for registered interface.  Function may call back
   1034 **                  with connection status and queued notifications
   1035 **
   1036 ** Parameter        gatt_if: applicaiton interface.
   1037 **
   1038 ** Returns          None
   1039 **
   1040 *******************************************************************************/
   1041     GATT_API extern  void GATT_StartIf (tGATT_IF gatt_if);
   1042 
   1043 /*******************************************************************************
   1044 **
   1045 ** Function         GATT_Connect
   1046 **
   1047 ** Description      This function initiate a connecttion to a ATT server.
   1048 **
   1049 ** Parameters       gatt_if: applicaiton interface
   1050 **                  bd_addr: peer device address.
   1051 **                  is_direct: is a direct conenection or a background auto connection
   1052 **
   1053 ** Returns          TRUE if connection started; FALSE if connection start failure.
   1054 **
   1055 *******************************************************************************/
   1056     GATT_API extern BOOLEAN GATT_Connect (tGATT_IF gatt_if, BD_ADDR bd_addr, BOOLEAN is_direct);
   1057 
   1058 
   1059 /*******************************************************************************
   1060 **
   1061 ** Function         GATT_CancelConnect
   1062 **
   1063 ** Description      This function initiate a cancel connecttion to a ATT server.
   1064 **
   1065 ** Parameters       gatt_if: client interface. If 0 used as unconditionally disconnect,
   1066 **                          typically used for direct connection cancellation.
   1067 **                  bd_addr: peer device address.
   1068 **                  is_direct: is a direct conenection or a background auto connection
   1069 **
   1070 ** Returns          TRUE if connection started; FALSE if connection start failure.
   1071 **
   1072 *******************************************************************************/
   1073     GATT_API extern BOOLEAN GATT_CancelConnect (tGATT_IF gatt_if, BD_ADDR bd_addr, BOOLEAN is_direct);
   1074 
   1075 /*******************************************************************************
   1076 **
   1077 ** Function         GATT_Disconnect
   1078 **
   1079 ** Description      This function disconnect a logic channel.
   1080 **
   1081 ** Parameters       conn_id: connection identifier.
   1082 **
   1083 ** Returns          GATT_SUCCESS if disconnected.
   1084 **
   1085 *******************************************************************************/
   1086     GATT_API extern tGATT_STATUS GATT_Disconnect (UINT16 conn_id);
   1087 
   1088 
   1089 
   1090 /*******************************************************************************
   1091 **
   1092 ** Function         GATT_GetConnectionInfor
   1093 **
   1094 ** Description      This function use conn_id to find its associated BD address and applciation
   1095 **                  interface
   1096 **
   1097 ** Parameters        conn_id: connection id  (input)
   1098 **                   p_gatt_if: applicaiton interface (output)
   1099 **                   bd_addr: peer device address. (output)
   1100 **
   1101 ** Returns          TRUE the ligical link information is found for conn_id
   1102 **
   1103 *******************************************************************************/
   1104     GATT_API extern BOOLEAN GATT_GetConnectionInfor(UINT16 conn_id, tGATT_IF *p_gatt_if, BD_ADDR bd_addr);
   1105 
   1106 
   1107 /*******************************************************************************
   1108 **
   1109 ** Function         GATT_GetConnIdIfConnected
   1110 **
   1111 ** Description      This function find the conn_id if the logical link for BD address
   1112 **                  and applciation interface is connected
   1113 **
   1114 ** Parameters        gatt_if: applicaiton interface (input)
   1115 **                   bd_addr: peer device address. (input)
   1116 **                   p_conn_id: connection id  (output)
   1117 **
   1118 ** Returns          TRUE the ligical link is connected
   1119 **
   1120 *******************************************************************************/
   1121     GATT_API extern BOOLEAN GATT_GetConnIdIfConnected(tGATT_IF gatt_if, BD_ADDR bd_addr, UINT16 *p_conn_id);
   1122 
   1123 #ifdef __cplusplus
   1124 
   1125 }
   1126 #endif
   1127 
   1128 #endif  /* GATT_API_H */
   1129