79 #define GATT_CLIENT_CHAR_CFG_UPDATED_EVENT 0x00 88 #define GATT_PROP_BCAST 0x01 89 #define GATT_PROP_READ 0x02 90 #define GATT_PROP_WRITE_NO_RSP 0x04 91 #define GATT_PROP_WRITE 0x08 92 #define GATT_PROP_NOTIFY 0x10 93 #define GATT_PROP_INDICATE 0x20 94 #define GATT_PROP_AUTHEN 0x40 95 #define GATT_PROP_EXTENDED 0x80 103 #define GATT_EXT_PROP_RELIABLE_WRITE 0x0001 104 #define GATT_EXT_PROP_WRITABLE_AUX 0x0002 112 #define GATT_CLIENT_CFG_NOTIFY 0x0001 113 #define GATT_CLIENT_CFG_INDICATE 0x0002 121 #define GATT_SERV_CFG_BCAST 0x0001 125 #define GATT_CFG_NO_OPERATION 0x0000 // No operation 131 #define GATT_FORMAT_BOOL 0x01 132 #define GATT_FORMAT_2BIT 0x02 133 #define GATT_FORMAT_NIBBLE 0x03 134 #define GATT_FORMAT_UINT8 0x04 135 #define GATT_FORMAT_UINT12 0x05 136 #define GATT_FORMAT_UINT16 0x06 137 #define GATT_FORMAT_UINT24 0x07 138 #define GATT_FORMAT_UINT32 0x08 139 #define GATT_FORMAT_UINT48 0x09 140 #define GATT_FORMAT_UINT64 0x0a 141 #define GATT_FORMAT_UINT128 0x0b 142 #define GATT_FORMAT_SINT8 0x0c 143 #define GATT_FORMAT_SINT12 0x0d 144 #define GATT_FORMAT_SINT16 0x0e 145 #define GATT_FORMAT_SINT24 0x0f 146 #define GATT_FORMAT_SINT32 0x10 147 #define GATT_FORMAT_SINT48 0x11 148 #define GATT_FORMAT_SINT64 0x12 149 #define GATT_FORMAT_SINT128 0x13 150 #define GATT_FORMAT_FLOAT32 0x14 151 #define GATT_FORMAT_FLOAT64 0x15 152 #define GATT_FORMAT_SFLOAT 0x16 153 #define GATT_FORMAT_FLOAT 0x17 154 #define GATT_FORMAT_DUINT16 0x18 155 #define GATT_FORMAT_UTF8S 0x19 156 #define GATT_FORMAT_UTF16S 0x1a 157 #define GATT_FORMAT_STRUCT 0x1b 165 #define GATT_NS_NONE 0x00 166 #define GATT_NS_BT_SIG 0x01 174 #define GATT_NS_BT_DESC_UNKNOWN 0x0000 179 #define GATT_ALL_SERVICES 0xFFFFFFFF 182 #define GATT_SERVICE 0x00000001 184 #if defined ( TESTMODES ) 186 #define GATT_TESTMODE_OFF 0 // Test mode off 187 #define GATT_TESTMODE_NO_RSP 1 // Ignore incoming request 188 #define GATT_TESTMODE_PREPARE_WRITE 2 // Forward Prepare Write Request right away 189 #define GATT_TESTMODE_MAX_MTU_SIZE 3 // Use Max ATT MTU size with Exchange MTU Rsp 190 #define GATT_TESTMODE_CORRUPT_PW_DATA 4 // Corrupt incoming Prepare Write Request data 194 #define GATT_PARAM_NUM_PREPARE_WRITES 0 // RW uint8 197 #define PTR_TYPE unsigned int * 200 #define GATT_LOCAL_READ 0xFF 201 #define GATT_LOCAL_WRITE 0xFE 212 #define GATT_NUM_ATTRS( attrs ) ( sizeof( attrs ) / sizeof( gattAttribute_t ) ) 215 #define GATT_SERVICE_HANDLE( attrs ) ( (attrs)[0].handle ) 218 #define GATT_INCLUDED_HANDLE( attrs, i ) ( *((uint16 *)((attrs)[(i)].pValue)) ) 221 #define GATT_CCC_TBL( pValue ) ( (gattCharCfg_t *)(*((PTR_TYPE)(pValue))) ) 262 uint8 *pValue, uint16 *pLen, uint16 offset,
263 uint16 maxLen, uint8 method );
296 uint8 *pValue, uint16 len, uint16 offset,
438 uint16 numAttrs, uint8 encKeySize,
466 uint16 numAttrs, uint8 *pValue );
600 uint8 *pValue, uint16 len, uint16 offset,
618 uint16 numAttrs, uint8 taskId,
665 uint16 service, uint8 *pValue, uint16 *pLen,
666 uint16 offset, uint16 maxLen, uint8 method );
681 uint8 *pValue, uint16 len, uint16 offset,
698 uint16 pLen, uint16 offset );
712 extern void GATTServApp_SetParamValue( uint16 value );
721 extern uint16 GATTServApp_GetParamValue(
void );
737 extern void GATTServApp_Init( uint8 taskId );
752 extern uint16 GATTServApp_ProcessEvent( uint8 taskId, uint16 events );
816 extern bStatus_t gattServApp_buildReadByTypeRsp( uint16 connHandle, uint8 *pAttrValue, uint16 attrLen, uint16 attrHandle );
827 extern prepareWrites_t *gattServApp_FindPrepareWriteQ( uint16 connHandle );
uint8 GATTServApp_WriteCharCfg(uint16 connHandle, gattCharCfg_t *charCfgTbl, uint16 value)
Write the client characteristic configuration for a given client.
Definition: gattservapp.h:386
pfnGATTWriteAttrCB_t pfnWriteAttrCB
Write callback function pointer.
Definition: gattservapp.h:343
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.
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:261
osal_event_hdr_t hdr
GATT_SERV_MSG_EVENT and status.
Definition: gattservapp.h:363
Definition: gattservapp.h:372
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:295
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.
bStatus_t GATTServApp_DeregisterService(uint16 handle, gattAttribute_t **p2pAttrs)
Deregister a service's attribute list and callback functions from the GATT Server Application...
Definition: gattservapp.h:340
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.
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...
uint8 value
Characteristic configuration value for this client.
Definition: gattservapp.h:333
Definition: gattservapp.h:379
void GATTServApp_InitCharCfg(uint16 connHandle, gattCharCfg_t *charCfgTbl)
Initialize the client characteristic configuration table.
uint16 connHandle
Connection message was received on.
Definition: gattservapp.h:364
uint8 method
GATT_CLIENT_CHAR_CFG_UPDATED_EVENT.
Definition: gattservapp.h:365
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:309
void GATTServApp_RegisterForMsg(uint8 taskID)
Register your task ID to receive event messages from the GATT Server Application. ...
uint16 connHandle
Connection message was received on.
Definition: gattservapp.h:353
uint16 attrHandle
attribute handle
Definition: gattservapp.h:366
bStatus_t GATTServApp_SendServiceChangedInd(uint16 connHandle, uint8 taskId)
Send out a Service Changed Indication.
Definition: gattservapp.h:330
pfnGATTReadAttrCB_t pfnReadAttrCB
Read callback function pointer.
Definition: gattservapp.h:342
uint16 GATTServApp_ReadCharCfg(uint16 connHandle, gattCharCfg_t *charCfgTbl)
Read the client characteristic configuration for a given client.
osal_event_hdr_t hdr
GATT_SERV_MSG_EVENT and status.
Definition: gattservapp.h:352
bStatus_t GATTServApp_DelService(uint32 services)
Delete function for the GATT Service.
Status_t bStatus_t
BLE Generic Status return: BLE Default BLE Status Values.
Definition: bcomdef.h:244
bStatus_t GATTServApp_SetParameter(uint8 param, uint8 len, void *pValue)
Set a GATT Server parameter.
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.
Definition: gattservapp.h:361
uint8 GATTServApp_WriteAttr(uint16 connHandle, uint16 handle, uint8 *pValue, uint16 len, uint16 offset, uint8 method)
Write attribute data.
bStatus_t GATTServApp_AddService(uint32 services)
Add function for the GATT Service.
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. ...
Definition: gattservapp.h:350
uint8 method
GATT type of command. Ref: GATT Server Message IDs.
Definition: gattservapp.h:354
uint16 value
attribute new value
Definition: gattservapp.h:367
bStatus_t GATTServApp_UpdateCharCfg(uint16 connHandle, uint16 attrHandle, uint16 value)
Update the Client Characteristic Configuration for a given Client.
uint16 connHandle
Client connection handle.
Definition: gattservapp.h:332
pfnGATTAuthorizeAttrCB_t pfnAuthorizeAttrCB
Authorization callback function pointer.
Definition: gattservapp.h:344
void GATTServApp_SendCCCUpdatedEvent(uint16 connHandle, uint16 attrHandle, uint16 value)
Build and send the GATT_CLIENT_CHAR_CFG_UPDATED_EVENT to the application.
bStatus_t GATTServApp_GetParameter(uint8 param, void *pValue)
Get a GATT Server parameter.