TI BLE5-Stack API Documentation  2.02.02.00
gapbondmgr.h
Go to the documentation of this file.
1 /******************************************************************************
2 
3  Group: WCS, BTS
4  $Target Device: DEVICES $
5 
6  ******************************************************************************
7  $License: BSD3 2010 $
8  ******************************************************************************
9  $Release Name: PACKAGE NAME $
10  $Release Date: PACKAGE RELEASE DATE $
11  *****************************************************************************/
12 
21 #ifndef GAPBONDMGR_H
22 #define GAPBONDMGR_H
23 
24 #ifdef __cplusplus
25 extern "C"
26 {
27 #endif
28 
29 /*-------------------------------------------------------------------
30  * INCLUDES
31  */
32 #include "gap.h"
33 
34 /*-------------------------------------------------------------------
35  * CONSTANTS
36  */
37 
43 // This is a common file for the legacy and sysconfig examples,
44 // the parameters under ifndef SYSCFG are defined in this file for
45 // the legacy examples and generated using the sysconfig tool for
46 // the sysconfig examples
47 #ifndef SYSCFG
48 #if !defined ( GAP_BONDINGS_MAX )
49 #define GAP_BONDINGS_MAX 10
51 #endif
52 
53 #if !defined ( GAP_CHAR_CFG_MAX )
54 #define GAP_CHAR_CFG_MAX 4
56 #endif
57 #endif //SYSCFG
58 
78 #define GAPBOND_PAIRING_MODE 0x400
79 
89 #define GAPBOND_MITM_PROTECTION 0x402
90 
100 #define GAPBOND_IO_CAPABILITIES 0x403
101 
111 #define GAPBOND_OOB_ENABLED 0x404
112 
123 #define GAPBOND_OOB_DATA 0x405
124 
134 #define GAPBOND_BONDING_ENABLED 0x406
135 
148 #define GAPBOND_KEY_DIST_LIST 0x407
149 
155 #define GAPBOND_ERASE_ALLBONDS 0x409
156 
158 #define GAPBOND_AUTO_FAIL_PAIRING 0x40A
159 #define GAPBOND_AUTO_FAIL_REASON 0x40B
160 
171 #define GAPBOND_KEYSIZE 0x40C
172 
186 #define GAPBOND_AUTO_SYNC_WL 0x40D
187 
195 #define GAPBOND_BOND_COUNT 0x40E
196 
207 #define GAPBOND_BOND_FAIL_ACTION 0x40F
208 
221 #define GAPBOND_ERASE_SINGLEBOND 0x410
222 
236 #define GAPBOND_SECURE_CONNECTION 0x411
237 
256 #define GAPBOND_ECCKEY_REGEN_POLICY 0x412
257 
279 #define GAPBOND_ECC_KEYS 0x413
280 
290 #define GAPBOND_SC_HOST_DEBUG 0x414
291 
308 #define GAPBOND_ERASE_BOND_IN_CONN 0x415
309 
327 #define GAPBOND_ALLOW_DEBUG_KEYS 0x416
328 
342 #define GAPBOND_LRU_BOND_REPLACEMENT 0x418
343 
352 #define GAPBOND_ERASE_LOCAL_INFO 0x41A
353 
363 #define GAPBOND_AUTHEN_PAIRING_ONLY 0x41B
364 
376 #define GAPBOND_PAIRING_MODE_NO_PAIRING 0x00
378 #define GAPBOND_PAIRING_MODE_WAIT_FOR_REQ 0x01
380 #define GAPBOND_PAIRING_MODE_INITIATE 0x02
382 
388 #define GAPBOND_IO_CAP_DISPLAY_ONLY 0x00
390 #define GAPBOND_IO_CAP_DISPLAY_YES_NO 0x01
392 #define GAPBOND_IO_CAP_KEYBOARD_ONLY 0x02
394 #define GAPBOND_IO_CAP_NO_INPUT_NO_OUTPUT 0x03
396 #define GAPBOND_IO_CAP_KEYBOARD_DISPLAY 0x04
398 
404 #define GAPBOND_KEYDIST_SENCKEY 0x01
406 #define GAPBOND_KEYDIST_SIDKEY 0x02
408 #define GAPBOND_KEYDIST_SSIGN 0x04
410 #define GAPBOND_KEYDIST_SLINK 0x08
412 #define GAPBOND_KEYDIST_MENCKEY 0x10
414 #define GAPBOND_KEYDIST_MIDKEY 0x20
416 #define GAPBOND_KEYDIST_MSIGN 0x40
418 #define GAPBOND_KEYDIST_MLINK 0x80
420 
456 #define GAP_BOND_REC_ID_OFFSET 0
457 #define GAP_BOND_LOCAL_LTK_OFFSET 1
458 #define GAP_BOND_DEV_LTK_OFFSET 2
459 #define GAP_BOND_DEV_IRK_OFFSET 3
460 #define GAP_BOND_DEV_CSRK_OFFSET 4
461 #define GAP_BOND_DEV_SIGN_COUNTER_OFFSET 5
462 #define GAP_BOND_REC_IDS 6
463 
464 // Bonded State Flags
465 #define GAP_BONDED_STATE_AUTHENTICATED 0x01
466 #define GAP_BONDED_STATE_SERVICE_CHANGED 0x02
467 #define GAP_BONDED_STATE_CAR 0x04
468 #define GAP_BONDED_STATE_SECURECONNECTION 0x08
469 #define GAP_BONDED_STATE_RPA_ONLY 0x10
470 
488 #define GAPBOND_PAIRING_STATE_STARTED 0x00
489 
509 #define GAPBOND_PAIRING_STATE_COMPLETE 0x01
510 
528 #define GAPBOND_PAIRING_STATE_ENCRYPTED 0x02
529 #define GAPBOND_PAIRING_STATE_BOND_SAVED 0x03
531 #define GAPBOND_PAIRING_STATE_CAR_READ 0x04
533 #define GAPBOND_PAIRING_STATE_RPAO_READ 0x05
535 #define GAPBOND_GENERATE_ECC_DONE 0x06
537 
552 #define SMP_PAIRING_FAILED_PASSKEY_ENTRY_FAILED 0x01
553 #define SMP_PAIRING_FAILED_OOB_NOT_AVAIL 0x02
555 
559 #define SMP_PAIRING_FAILED_AUTH_REQ 0x03
560 #define SMP_PAIRING_FAILED_CONFIRM_VALUE 0x04
562 #define SMP_PAIRING_FAILED_NOT_SUPPORTED 0x05
564 
568 #define SMP_PAIRING_FAILED_ENC_KEY_SIZE 0x06
569 #define SMP_PAIRING_FAILED_CMD_NOT_SUPPORTED 0x07
571 #define SMP_PAIRING_FAILED_UNSPECIFIED 0x08
573 
577 #define SMP_PAIRING_FAILED_REPEATED_ATTEMPTS 0x09
578 
582 #define SMP_PAIRING_FAILED_INVALID_PARAMETERS 0x0A
583 
587 #define SMP_PAIRING_FAILED_DHKEY_CHECK_FAILED 0x0B
588 
592 #define SMP_PAIRING_FAILED_NUM_COMPARISON_FAILED 0x0C
593 
599 #define GAPBOND_FAIL_NO_ACTION 0x00
601 #define GAPBOND_FAIL_INITIATE_PAIRING 0x01
603 #define GAPBOND_FAIL_TERMINATE_LINK 0x02
605 
609 #define GAPBOND_FAIL_TERMINATE_ERASE_BONDS 0x03
610 
616 #define GAPBOND_SECURE_CONNECTION_NONE 0x00
618 #define GAPBOND_SECURE_CONNECTION_ALLOW 0x01
620 #define GAPBOND_SECURE_CONNECTION_ONLY 0x02
622 
632 #define GAPBOND_REGENERATE_ALWAYS 0x00
634 #define GAPBOND_REGENERATE_NEVER 0xFF
636 
638 #define ECC_KEYLEN 32
640 
643 /*-------------------------------------------------------------------
644  * TYPEDEFS
645  */
646 
670 typedef void (*pfnPasscodeCB_t)
671 (
672  uint8_t *deviceAddr,
673  uint16_t connectionHandle,
674  uint8_t uiInputs,
675  uint8_t uiOutputs,
676  uint32_t numComparison
677 );
678 
690 typedef void (*pfnPairStateCB_t)
691 (
692  uint16_t connectionHandle,
693  uint8_t state,
694  uint8_t status
695 );
696 
703 typedef struct
704 {
707 } gapBondCBs_t;
708 
716 typedef struct
718 {
719  uint8_t privateKey[ECC_KEYLEN];
720  uint8_t publicKeyX[ECC_KEYLEN];
721  uint8_t publicKeyY[ECC_KEYLEN];
723 
724 //structure of OOB data
725 typedef struct gapBondOOBData
726 {
727  uint8 confirm[KEYLEN]; //calculated/received confirm value
728  uint8 rand[KEYLEN]; //calculated/received random number
729 } gapBondOOBData_t;
730 
732 typedef struct
733 {
734  uint8_t LTK[KEYLEN]; // Long Term Key (LTK)
735  uint16_t div; //lint -e754 // LTK eDiv
736  uint8_t rand[B_RANDOM_NUM_SIZE]; // LTK random number
737  uint8_t keySize; // LTK key size
738 } gapBondLTK_t;
739 
741 typedef struct
742 {
749  uint8_t addr[B_ADDR_LEN];
759  uint8_t stateFlags;
760 } gapBondRec_t;
761 
763 typedef struct
764 {
765  uint16_t attrHandle; // attribute handle
766  uint8_t value; // attribute value for this device
768 
770 /*-------------------------------------------------------------------
771  * API's
772  */
773 
779 extern void GAPBondMgr_Register(gapBondCBs_t *pCB);
780 
797 extern bStatus_t GAPBondMgr_SetParameter(uint16_t param, uint8_t len,
798  void *pValue);
799 
814 extern bStatus_t GAPBondMgr_GetParameter(uint16_t param, void *pValue);
815 
834 extern bStatus_t GAPBondMgr_Pair(uint16_t connHandle);
835 
864 extern bStatus_t GAPBondMgr_FindAddr(uint8_t *pDevAddr,
865  GAP_Peer_Addr_Types_t addrType,
866  uint8_t *pIdx,
867  GAP_Peer_Addr_Types_t *pIdentityAddrType,
868  uint8_t *pIdentityAddr);
869 
882 extern bStatus_t GAPBondMgr_ServiceChangeInd(uint16_t connectionHandle,
883  uint8_t setParam);
884 
899 extern bStatus_t GAPBondMgr_PasscodeRsp(uint16_t connectionHandle,
900  uint8_t status, uint32_t passcode);
901 
912 extern bStatus_t GAPBondMgr_SCGetLocalOOBParameters(gapBondOOBData_t *localOobData);
913 
926 extern bStatus_t GAPBondMgr_SCSetRemoteOOBParameters(gapBondOOBData_t *remoteOobData,
927  uint8 OOBDataFlag);
928 
938 
953 extern uint8_t gapBondMgrReadBondRec(GAP_Peer_Addr_Types_t addrType,
954  uint8_t *pDevAddr,
955  gapBondRec_t* pBondRec,
956  gapBondLTK_t* pLocalLtk,
957  gapBondLTK_t* pDevLtk,
958  uint8_t* pIRK,
959  uint8_t* pSRK,
960  uint32_t signCount,
961  gapBondCharCfg_t* charCfg);
962 
977 extern uint8_t gapBondMgrImportBond(gapBondRec_t* pBondRec,
978  gapBondLTK_t* pLocalLtk,
979  gapBondLTK_t* pDevLtk,
980  uint8_t* pIRK,
981  uint8_t* pSRK,
982  uint32_t signCount,
983  gapBondCharCfg_t* charCfg);
984 /*-------------------------------------------------------------------
985 -------------------------------------------------------------------*/
986 #ifdef __cplusplus
987 }
988 #endif
989 
990 #endif /* GAPBONDMGR_H */
991 
GAP_Peer_Addr_Types_t
Address types used for specifying peer address type.
Definition: gap.h:727
Public and Private ECC Keys.
Definition: gapbondmgr.h:717
bStatus_t GAPBondMgr_Pair(uint16_t connHandle)
#define B_RANDOM_NUM_SIZE
BLE Random Number Size.
Definition: bcomdef.h:133
Structure of NV data for the connected device's encryption information.
Definition: gapbondmgr.h:732
bStatus_t GAPBondMgr_GenerateEccKeys(void)
Generates ECC keys.
bStatus_t GAPBondMgr_GetParameter(uint16_t param, void *pValue)
bStatus_t GAPBondMgr_PasscodeRsp(uint16_t connectionHandle, uint8_t status, uint32_t passcode)
void(* pfnPairStateCB_t)(uint16_t connectionHandle, uint8_t state, uint8_t status)
Definition: gapbondmgr.h:691
bStatus_t GAPBondMgr_SCGetLocalOOBParameters(gapBondOOBData_t *localOobData)
Get local Random number and confirm value for secure connection.
Structure of NV data for the connected device's address information.
Definition: gapbondmgr.h:741
pfnPasscodeCB_t passcodeCB
Passcode callback.
Definition: gapbondmgr.h:705
bStatus_t GAPBondMgr_FindAddr(uint8_t *pDevAddr, GAP_Peer_Addr_Types_t addrType, uint8_t *pIdx, GAP_Peer_Addr_Types_t *pIdentityAddrType, uint8_t *pIdentityAddr)
Search for an address in the bonding table. If the address is a random private resolvable address...
void GAPBondMgr_Register(gapBondCBs_t *pCB)
Definition: gapbondmgr.h:703
void(* pfnPasscodeCB_t)(uint8_t *deviceAddr, uint16_t connectionHandle, uint8_t uiInputs, uint8_t uiOutputs, uint32_t numComparison)
Definition: gapbondmgr.h:671
uint8_t gapBondMgrImportBond(gapBondRec_t *pBondRec, gapBondLTK_t *pLocalLtk, gapBondLTK_t *pDevLtk, uint8_t *pIRK, uint8_t *pSRK, uint32_t signCount, gapBondCharCfg_t *charCfg)
Import bond record to NV.
uint8_t gapBondMgrReadBondRec(GAP_Peer_Addr_Types_t addrType, uint8_t *pDevAddr, gapBondRec_t *pBondRec, gapBondLTK_t *pLocalLtk, gapBondLTK_t *pDevLtk, uint8_t *pIRK, uint8_t *pSRK, uint32_t signCount, gapBondCharCfg_t *charCfg)
Read bond record from NV.
uint8_t stateFlags
Definition: gapbondmgr.h:759
GAP layer interface.
bStatus_t GAPBondMgr_ServiceChangeInd(uint16_t connectionHandle, uint8_t setParam)
GAP_Peer_Addr_Types_t addrType
Definition: gapbondmgr.h:753
#define B_ADDR_LEN
Default Public and Random Address Length.
Definition: bcomdef.h:108
bStatus_t GAPBondMgr_SetParameter(uint16_t param, uint8_t len, void *pValue)
Status_t bStatus_t
BLE Generic Status return.
Definition: bcomdef.h:251
#define ECC_KEYLEN
ECC Key Length: 256 bit keys.
Definition: gapbondmgr.h:639
bStatus_t GAPBondMgr_SCSetRemoteOOBParameters(gapBondOOBData_t *remoteOobData, uint8 OOBDataFlag)
Set remote's OOB parameters for secure connection.
#define KEYLEN
Default key length.
Definition: bcomdef.h:111
pfnPairStateCB_t pairStateCB
Pairing state callback.
Definition: gapbondmgr.h:706
Structure of NV data for the connected device's characteristic configuration.
Definition: gapbondmgr.h:763
© Copyright 1995-2021, Texas Instruments Incorporated. All rights reserved.
Trademarks | Privacy policy | Terms of use | Terms of sale