TI BLE5-Stack API Documentation  2.02.00.00
gattservapp.h
Go to the documentation of this file.
1 /******************************************************************************
2 
3  Group: WCS, BTS
4  $Target Device: DEVICES $
5 
6  ******************************************************************************
7  $License: BSD3 2009 $
8  ******************************************************************************
9  $Release Name: PACKAGE NAME $
10  $Release Date: PACKAGE RELEASE DATE $
11  *****************************************************************************/
12 
21 #ifndef GATTSERVAPP_H
22 #define GATTSERVAPP_H
23 
24 #ifdef __cplusplus
25 extern "C"
26 {
27 #endif
28 
29 /*********************************************************************
30  * INCLUDES
31  */
32 #include "bcomdef.h"
33 #include "osal.h"
34 
35 /*********************************************************************
36  * CONSTANTS
37  */
38 
49 #define GATT_CLIENT_CHAR_CFG_UPDATED_EVENT 0x00
50 
51 
59 #define GATT_PROP_BCAST 0x01
60 #define GATT_PROP_READ 0x02
61 #define GATT_PROP_WRITE_NO_RSP 0x04
62 #define GATT_PROP_WRITE 0x08
63 #define GATT_PROP_NOTIFY 0x10
64 #define GATT_PROP_INDICATE 0x20
65 #define GATT_PROP_AUTHEN 0x40
66 #define GATT_PROP_EXTENDED 0x80
67 
68 
75 #define GATT_EXT_PROP_RELIABLE_WRITE 0x0001
76 #define GATT_EXT_PROP_WRITABLE_AUX 0x0002
77 
78 
85 #define GATT_CLIENT_CFG_NOTIFY 0x0001
86 #define GATT_CLIENT_CFG_INDICATE 0x0002
87 
88 
95 #define GATT_SERV_CFG_BCAST 0x0001
96 
97 
99 #define GATT_CFG_NO_OPERATION 0x0000
100 
101 
106 #define GATT_FORMAT_BOOL 0x01
107 #define GATT_FORMAT_2BIT 0x02
108 #define GATT_FORMAT_NIBBLE 0x03
109 #define GATT_FORMAT_UINT8 0x04
110 #define GATT_FORMAT_UINT12 0x05
111 #define GATT_FORMAT_UINT16 0x06
112 #define GATT_FORMAT_UINT24 0x07
113 #define GATT_FORMAT_UINT32 0x08
114 #define GATT_FORMAT_UINT48 0x09
115 #define GATT_FORMAT_UINT64 0x0a
116 #define GATT_FORMAT_UINT128 0x0b
117 #define GATT_FORMAT_SINT8 0x0c
118 #define GATT_FORMAT_SINT12 0x0d
119 #define GATT_FORMAT_SINT16 0x0e
120 #define GATT_FORMAT_SINT24 0x0f
121 #define GATT_FORMAT_SINT32 0x10
122 #define GATT_FORMAT_SINT48 0x11
123 #define GATT_FORMAT_SINT64 0x12
124 #define GATT_FORMAT_SINT128 0x13
125 #define GATT_FORMAT_FLOAT32 0x14
126 #define GATT_FORMAT_FLOAT64 0x15
127 #define GATT_FORMAT_SFLOAT 0x16
128 #define GATT_FORMAT_FLOAT 0x17
129 #define GATT_FORMAT_DUINT16 0x18
130 #define GATT_FORMAT_UTF8S 0x19
131 #define GATT_FORMAT_UTF16S 0x1a
132 #define GATT_FORMAT_STRUCT 0x1b
133 
134 
140 #define GATT_NS_NONE 0x00
141 #define GATT_NS_BT_SIG 0x01
142 #define GATT_NS_BT_DESC_UNKNOWN 0x0000
143 
145 #define GATT_ALL_SERVICES 0xFFFFFFFF
147 
149 #define GATT_SERVICE 0x00000001
150 
152 #if defined ( TESTMODES )
153  // GATT Test Modes
154  #define GATT_TESTMODE_OFF 0 // Test mode off
155  #define GATT_TESTMODE_NO_RSP 1 // Ignore incoming request
156  #define GATT_TESTMODE_PREPARE_WRITE 2 // Forward Prepare Write Request right away
157  #define GATT_TESTMODE_MAX_MTU_SIZE 3 // Use Max ATT MTU size with Exchange MTU Rsp
158  #define GATT_TESTMODE_CORRUPT_PW_DATA 4 // Corrupt incoming Prepare Write Request data
159 #endif
160 
166 #define GATT_PARAM_NUM_PREPARE_WRITES 0
167 
169 #define PTR_TYPE unsigned int *
172 
175 #define GATT_LOCAL_READ 0xFF
176 #define GATT_LOCAL_WRITE 0xFE
178 
181 /*********************************************************************
182  * VARIABLES
183  */
184 
185 /*********************************************************************
186  * MACROS
187  */
188 
190 #define GATT_NUM_ATTRS( attrs ) ( sizeof( attrs ) / sizeof( gattAttribute_t ) )
191 
193 #define GATT_SERVICE_HANDLE( attrs ) ( (attrs)[0].handle )
194 
196 #define GATT_INCLUDED_HANDLE( attrs, i ) ( *((uint16 *)((attrs)[(i)].pValue)) )
197 
199 #define GATT_CCC_TBL( pValue ) ( (gattCharCfg_t *)(*((PTR_TYPE)(pValue))) )
200 
201 /*********************************************************************
202  * TYPEDEFS
203  */
204 
241 typedef bStatus_t (*pfnGATTReadAttrCB_t)( uint16 connHandle, gattAttribute_t *pAttr,
242  uint8 *pValue, uint16 *pLen, uint16 offset,
243  uint16 maxLen, uint8 method );
244 
276 typedef bStatus_t (*pfnGATTWriteAttrCB_t)( uint16 connHandle, gattAttribute_t *pAttr,
277  uint8 *pValue, uint16 len, uint16 offset,
278  uint8 method );
290 typedef bStatus_t (*pfnGATTAuthorizeAttrCB_t)( uint16 connHandle, gattAttribute_t *pAttr,
291  uint8 opcode );
292 
300 typedef struct
302 {
303  uint8 format;
304  int8 exponent;
305  uint16 unit;
306  uint8 nameSpace;
307  uint16 desc;
309 
311 typedef struct
312 {
313  uint16 connHandle;
314  uint8 value;
315 } gattCharCfg_t;
316 
323 typedef struct
324 {
329 
331 typedef struct
332 {
334  uint16 connHandle;
335  uint8 method;
337 
344 typedef struct
345 {
347  uint16 connHandle;
348  uint8 method;
349  uint16 attrHandle;
350  uint16 value;
352 
353 
355 typedef struct
356 {
357  uint16 connHandle;
360 
362 typedef struct
363 {
364  uint16 handle;
367 
369 typedef struct _serviceCBsList
370 {
374 
375 
376 /*********************************************************************
377  * VARIABLES
378  */
379 
382 
385 
388 /*********************************************************************
389  * API FUNCTIONS
390  */
391 
398 extern void GATTServApp_RegisterForMsg( uint8 taskID );
399 
416  uint16 numAttrs, uint8 encKeySize,
417  CONST gattServiceCBs_t *pServiceCBs );
418 
433 bStatus_t GATTServApp_DeregisterService( uint16 handle, gattAttribute_t **p2pAttrs );
434 
447  uint16 numAttrs, uint8 *pValue );
459 extern bStatus_t GATTServApp_AddService( uint32 services );
460 
470 extern bStatus_t GATTServApp_DelService( uint32 services );
471 
488 extern bStatus_t GATTServApp_SetParameter( uint8 param, uint8 len, void *pValue );
489 
502 extern bStatus_t GATTServApp_GetParameter( uint8 param, void *pValue );
503 
518 extern bStatus_t GATTServApp_UpdateCharCfg( uint16 connHandle, uint16 attrHandle, uint16 value );
519 
532 extern void GATTServApp_InitCharCfg( uint16 connHandle, gattCharCfg_t *charCfgTbl );
533 
549 extern uint16 GATTServApp_ReadCharCfg( uint16 connHandle, gattCharCfg_t *charCfgTbl );
550 
567 extern uint8 GATTServApp_WriteCharCfg( uint16 connHandle, gattCharCfg_t *charCfgTbl, uint16 value );
568 
587 extern bStatus_t GATTServApp_ProcessCCCWriteReq( uint16 connHandle, gattAttribute_t *pAttr,
588  uint8 *pValue, uint16 len, uint16 offset,
589  uint16 validCfg );
590 
609 extern bStatus_t GATTServApp_ProcessCharCfg( gattCharCfg_t *charCfgTbl, uint8 *pValue,
610  uint8 authenticated, gattAttribute_t *attrTbl,
611  uint16 numAttrs, uint8 taskId,
612  pfnGATTReadAttrCB_t pfnReadAttrCB );
613 
622 extern void GATTServApp_SendCCCUpdatedEvent( uint16 connHandle, uint16 attrHandle, uint16 value );
623 
637 extern bStatus_t GATTServApp_SendServiceChangedInd( uint16 connHandle, uint8 taskId );
638 
656 extern uint8 GATTServApp_ReadAttr( uint16 connHandle, gattAttribute_t *pAttr,
657  uint16 service, uint8 *pValue, uint16 *pLen,
658  uint16 offset, uint16 maxLen, uint8 method );
659 
673 extern uint8 GATTServApp_WriteAttr( uint16 connHandle, uint16 handle,
674  uint8 *pValue, uint16 len, uint16 offset,
675  uint8 method );
676 
690 extern bStatus_t GATTServApp_ReadRsp( uint16 connHandle, uint8 *pValue,
691  uint16 pLen, uint16 offset );
692 
699 extern void GATTServApp_SetParamValue( uint16 value );
700 
706 extern uint16 GATTServApp_GetParamValue( void );
707 
708 /*-------------------------------------------------------------------
709  * TASK API - These functions must only be called by OSAL.
710  */
711 
713 
724 extern void GATTServApp_Init( uint8 taskId, uint8_t cfg_GATTServApp_att_delayed_req, uint8_t cfg_gapBond_gatt_no_service_changed );
725 
737 extern uint16 GATTServApp_ProcessEvent( uint8 taskId, uint16 events );
738 
748 extern pfnGATTAuthorizeAttrCB_t gattServApp_FindAuthorizeAttrCB( uint16 handle );
749 
760 extern bStatus_t gattServApp_EnqueuePrepareWriteReq( uint16 connHandle, attPrepareWriteReq_t *pReq );
761 
773 extern bStatus_t gattServApp_ProcessWriteLong( gattMsgEvent_t *pMsg, prepareWrites_t *pQueue, uint16 *pErrHandle );
774 
786 extern bStatus_t gattServApp_ProcessReliableWrites( gattMsgEvent_t *pMsg, prepareWrites_t *pQueue, uint16 *pErrHandle );
787 
801 extern bStatus_t gattServApp_buildReadByTypeRsp( uint16 connHandle, uint8 *pAttrValue, uint16 attrLen, uint16 attrHandle );
802 
812 extern prepareWrites_t *gattServApp_FindPrepareWriteQ( uint16 connHandle );
813 
824 extern uint8 gattServApp_IsWriteLong( attExecuteWriteReq_t *pReq, prepareWrites_t *pQueue );
825 
833 extern void gattServApp_ClearPrepareWriteQ( prepareWrites_t *pQueue );
834 
847 extern bStatus_t gattServApp_EnqueueReTx( uint16 connHandle, uint8 method,
848  gattMsg_t *pMsg );
849 
859 extern void gattServApp_DequeueReTx( void );
860 
862 
863 /*********************************************************************
864 *********************************************************************/
865 
866 #ifdef __cplusplus
867 }
868 #endif
869 
870 #endif /* GATTSERVAPP_H */
871 
uint16 GATTServApp_GetParamValue(void)
Get a GATT Server Application Parameter value.
GATT Structure for Characteristic Presentation Format Value.
Definition: gattservapp.h:301
This API allows the software components in the Z-Stack to be written independently of the specifics o...
uint16 connHandle
Connection message was received on.
Definition: gattservapp.h:334
gattServiceCBsInfo_t serviceInfo
service handle/callbacks
Definition: gattservapp.h:372
GATT Server App event header format.
Definition: gattservapp.h:331
void GATTServApp_SetParamValue(uint16 value)
Set a GATT Server Application Parameter value. Use this function to change the default GATT parameter...
gattAttribute_t * GATTServApp_FindAttr(gattAttribute_t *pAttrTbl, uint16 numAttrs, uint8 *pValue)
Find the attribute record within a service attribute table for a given attribute value pointer...
pfnGATTAuthorizeAttrCB_t pfnAuthorizeAttrCB
Authorization callback function pointer.
Definition: gattservapp.h:327
Service callbacks list item.
Definition: gattservapp.h:369
void GATTServApp_SendCCCUpdatedEvent(uint16 connHandle, uint16 attrHandle, uint16 value)
Build and send the GATT_CLIENT_CHAR_CFG_UPDATED_EVENT to the application.
uint16 handle
Service handle - assigned internally by GATT Server.
Definition: gattservapp.h:364
Structure to keep Prepare Write Requests for each Client.
Definition: gattservapp.h:355
bStatus_t GATTServApp_GetParameter(uint8 param, void *pValue)
Get a GATT Server parameter.
pfnGATTWriteAttrCB_t pfnWriteAttrCB
Write callback function pointer.
Definition: gattservapp.h:326
prepareWrites_t * prepareWritesTbl
Server Prepare Write table (one entry per each physical link)
GATT Structure to keep CBs information for each service being registered.
Definition: gattservapp.h:362
uint8 value
Characteristic configuration value for this client.
Definition: gattservapp.h:314
bStatus_t GATTServApp_AddService(uint32 services)
Add function for the GATT Service.
pfnGATTReadAttrCB_t pfnReadAttrCB
Read callback function pointer.
Definition: gattservapp.h:325
bStatus_t(* pfnGATTReadAttrCB_t)(uint16 connHandle, gattAttribute_t *pAttr, uint8 *pValue, uint16 *pLen, uint16 offset, uint16 maxLen, uint8 method)
Callback function prototype to read an attribute value.
Definition: gattservapp.h:241
uint8 format
Format of the value of this characteristic.
Definition: gattservapp.h:303
bStatus_t GATTServApp_ReadRsp(uint16 connHandle, uint8 *pValue, uint16 pLen, uint16 offset)
If a service returns blePending to the read attribute call back invoked from GATTServApp, the service can later respond to with the value to be read using this API.
GATT Message format.
Definition: gatt.h:166
uint8 GATTServApp_WriteAttr(uint16 connHandle, uint16 handle, uint8 *pValue, uint16 len, uint16 offset, uint8 method)
Write attribute data.
struct _serviceCBsList * next
pointer to next service callbacks record
Definition: gattservapp.h:371
Structure for Client Characteristic Configuration.
Definition: gattservapp.h:311
osal_event_hdr_t hdr
GATT_SERV_MSG_EVENT and status.
Definition: gattservapp.h:333
uint16 connHandle
Client connection handle.
Definition: gattservapp.h:313
bStatus_t GATTServApp_ProcessCharCfg(gattCharCfg_t *charCfgTbl, uint8 *pValue, uint8 authenticated, gattAttribute_t *attrTbl, uint16 numAttrs, uint8 taskId, pfnGATTReadAttrCB_t pfnReadAttrCB)
Process Client Characteristic Configuration change.
uint16 GATTServApp_ReadCharCfg(uint16 connHandle, gattCharCfg_t *charCfgTbl)
Read the client characteristic configuration for a given client.
void GATTServApp_RegisterForMsg(uint8 taskID)
Register your task ID to receive event messages from the GATT Server Application. ...
attPrepareWriteReq_t * pPrepareWriteQ
Prepare Write Request queue.
Definition: gattservapp.h:358
void GATTServApp_InitCharCfg(uint16 connHandle, gattCharCfg_t *charCfgTbl)
Initialize the client characteristic configuration table.
uint16 value
attribute new value
Definition: gattservapp.h:350
uint16 connHandle
Connection message was received on.
Definition: gattservapp.h:347
Type definitions and macros for BLE stack.
bStatus_t GATTServApp_SetParameter(uint8 param, uint8 len, void *pValue)
Set a GATT Server parameter.
bStatus_t GATTServApp_SendServiceChangedInd(uint16 connHandle, uint8 taskId)
Send out a Service Changed Indication.
bStatus_t GATTServApp_DelService(uint32 services)
Delete function for the GATT Service.
uint16 connHandle
connection message was received on
Definition: gattservapp.h:357
uint16 attrHandle
attribute handle
Definition: gattservapp.h:349
serviceCBsList_t * serviceCBsList
Callbacks for services.
OSAL Event Header.
Definition: osal.h:92
GATT_CLIENT_CHAR_CFG_UPDATED_EVENT message format.
Definition: gattservapp.h:344
uint16 unit
Unit of this attribute as defined in the data dictionary.
Definition: gattservapp.h:305
uint8 nameSpace
Name space of the description.
Definition: gattservapp.h:306
struct _serviceCBsList serviceCBsList_t
Service callbacks list item.
GATT GATT_MSG_EVENT message format.
Definition: gatt.h:212
uint8 method
GATT type of command. Ref: GATT Server Message IDs.
Definition: gattservapp.h:335
bStatus_t GATTServApp_RegisterService(gattAttribute_t *pAttrs, uint16 numAttrs, uint8 encKeySize, CONST gattServiceCBs_t *pServiceCBs)
Register a service's attribute list and callback functions with the GATT Server Application.
bStatus_t GATTServApp_ProcessCCCWriteReq(uint16 connHandle, gattAttribute_t *pAttr, uint8 *pValue, uint16 len, uint16 offset, uint16 validCfg)
Process the client characteristic configuration write request for a given client. ...
osal_event_hdr_t hdr
GATT_SERV_MSG_EVENT and status.
Definition: gattservapp.h:346
GATT Attribute format.
Definition: gatt.h:241
Status_t bStatus_t
BLE Generic Status return.
Definition: bcomdef.h:251
CONST gattServiceCBs_t * pCBs
Service callback function pointers.
Definition: gattservapp.h:365
uint16 desc
Description of this attribute as defined in a higher layer profile.
Definition: gattservapp.h:307
Prepare Write Request format.
Definition: att.h:554
uint8 method
GATT_CLIENT_CHAR_CFG_UPDATED_EVENT.
Definition: gattservapp.h:348
int8 exponent
A sign integer which represents the exponent of an integer.
Definition: gattservapp.h:304
bStatus_t GATTServApp_UpdateCharCfg(uint16 connHandle, uint16 attrHandle, uint16 value)
Update the Client Characteristic Configuration for a given Client.
uint8 GATTServApp_WriteCharCfg(uint16 connHandle, gattCharCfg_t *charCfgTbl, uint16 value)
Write the client characteristic configuration for a given client.
GATT Structure for service callback functions.
Definition: gattservapp.h:323
bStatus_t(* pfnGATTAuthorizeAttrCB_t)(uint16 connHandle, gattAttribute_t *pAttr, uint8 opcode)
Callback function prototype to authorize a Read or Write operation on a given attribute.
Definition: gattservapp.h:290
Execute Write Request format.
Definition: att.h:580
bStatus_t GATTServApp_DeregisterService(uint16 handle, gattAttribute_t **p2pAttrs)
Deregister a service's attribute list and callback functions from the GATT Server Application...
bStatus_t(* pfnGATTWriteAttrCB_t)(uint16 connHandle, gattAttribute_t *pAttr, uint8 *pValue, uint16 len, uint16 offset, uint8 method)
Callback function prototype to write an attribute value.
Definition: gattservapp.h:276
uint8 GATTServApp_ReadAttr(uint16 connHandle, gattAttribute_t *pAttr, uint16 service, uint8 *pValue, uint16 *pLen, uint16 offset, uint16 maxLen, uint8 method)
Read an attribute. If the format of the attribute value is unknown to GATT Server, use the callback function provided by the Service.
© Copyright 1995-2021, Texas Instruments Incorporated. All rights reserved.
Trademarks | Privacy policy | Terms of use | Terms of sale