HW layer for the Nucleo board, it only work with old BLE_API
Dependents: Hello_BLE F446RE-BLE
Fork of X_NUCLEO_IDB0XA1 by
hci/inc/sm.h
- Committer:
- mridup
- Date:
- 2014-07-16
- Revision:
- 0:309c845d289d
File content as of revision 0:309c845d289d:
/******************** (C) COPYRIGHT 2012 STMicroelectronics ******************** * File Name : sm.h * Author : AMS - HEA&RF BU * Version : V1.0.0 * Date : 19-July-2012 * Description : Header file for BlueNRG's security manager. ******************************************************************************** * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME. * AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY DIRECT, * INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE * CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING * INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS. *******************************************************************************/ #ifndef __SM_H__ #define __SM_H__ /****************************************************************************** * Macros *****************************************************************************/ /* IO capabilities */ typedef tHalUint8 tSMIoCapability; #define IO_CAP_DISPLAY_ONLY (0x00) #define IO_CAP_DISPLAY_YES_NO (0x01) #define KEYBOARD_ONLY (0x02) #define IO_CAP_NO_INPUT_NO_OUTPUT (0x03) #define IO_CAP_KEYBOARD_DISPLAY (0x04) /* authentication requirements */ typedef tHalUint8 tSMBondingMode; #define BONDING (0x01) #define NO_BONDING (0x00) typedef tHalUint8 tSMMIMTMode; #define MITM_PROTECTION_NOT_REQUIRED (0x00) #define MITM_PROTECTION_REQUIRED (0x01) #define OOB_AUTH_DATA_ABSENT (0x00) #define OOB_AUTH_DATA_PRESENT (0x01) #define AUTHORIZATION_NOT_REQUIRED (0x00) #define AUTHORIZATION_REQUIRED (0x01) /* valid authorization responses */ #define CONNECTION_AUTHORIZED (0x01) #define CONNECTION_REJECTED (0x02) #define USE_FIXED_PIN_FOR_PAIRING (0x0) #define DONOT_USE_FIXED_PIN_FOR_PAIRING (0x01) #define PASSKEY_ENTERED (0x02) /* link security status */ #define SM_LINK_AUTHENTICATED (0x01) #define SM_LINK_AUTHORIZED (0x02) #define SM_LINK_ENCRYPTED (0x04) /* SMP pairing failed reason codes */ #define PASSKEY_ENTRY_FAILED (0x01) #define OOB_NOT_AVAILABLE (0x02) #define AUTH_REQ_CANNOT_BE_MET (0x03) #define CONFIRM_VALUE_FAILED (0x04) #define PAIRING_NOT_SUPPORTED (0x05) #define INSUFF_ENCRYPTION_KEY_SIZE (0x06) #define CMD_NOT_SUPPORTED (0x07) #define UNSPECIFIED_REASON (0x08) #define VERY_EARLY_NEXT_ATTEMPT (0x09) #define SM_INVALID_PARAMS (0x0A) /* error codes to be sent with the pairing complete event */ #define SM_PAIRING_TIMEOUT (0x01) #define SM_PAIRING_FAILED (0x02) #endif /* __SM_H__ */