/** ****************************************************************************** * @file bluenrg1_gap_aci.h * @author AMG - RF Application team * @version V1.0.0 * @date 31 May 2018 * @brief Header file for external uC - BlueNRG-x in network coprocessor mode (gap_aci) * Autogenerated files, do not edit!! ****************************************************************************** * @attention * * 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. * *

© COPYRIGHT STMicroelectronics

****************************************************************************** */ #ifndef _BLUENRG1_GAP_ACI_H_ #define _BLUENRG1_GAP_ACI_H_ #include "bluenrg1_types.h" /** Documentation for C struct Whitelist_Entry_t */ typedef struct Whitelist_Entry_t_s { /** Address type. * Values: - 0x00: Public Device Address - 0x01: Random Device Address */ uint8_t Peer_Address_Type; /** Public Device Address or Random Device Address of the device to be added to the white list. */ uint8_t Peer_Address[6]; } Whitelist_Entry_t; /** Documentation for C struct Bonded_Device_Entry_t */ typedef struct Bonded_Device_Entry_t_s { /** Address type. * Values: - 0x00: Public Device Address - 0x01: Random Device Address */ uint8_t Address_Type; /** Public Device Address or Random Device Address of the device to be added to the white list. */ uint8_t Address[6]; } Bonded_Device_Entry_t; /** Documentation for C struct Whitelist_Identity_Entry_t */ typedef struct Whitelist_Identity_Entry_t_s { /** Identity address type. * Values: - 0x00: Public Identity Address - 0x01: Random (static) Identity Address */ uint8_t Peer_Identity_Address_Type; /** Public or Random (static) Identity address of the peer device */ uint8_t Peer_Identity_Address[6]; } Whitelist_Identity_Entry_t; /** * @brief Put the device in non-discoverable mode. This command disables the LL advertising. * @retval Value indicating success or error code. */ tBleStatus aci_gap_set_non_discoverable(void); /** * @brief Put the device in limited discoverable mode (as defined in Bluetooth Specification v.4.1, Vol. 3, Part C, section 9.2.3). The device will be discoverable for maximum period of TGAP (lim_adv_timeout) = 180 seconds (from errata). The advertising can be disabled at any time by issuing @ref aci_gap_set_non_discoverable command. The Adv_Interval_Min and Adv_Interval_Max parameters are optional. If both are set to 0, the GAP will use default values for adv intervals for limited discoverable mode (250 ms and 500 ms respectively). To allow a fast connection, the host can set Local_Name, Service_Uuid_List, Slave_Conn_Interval_Min and Slave_Conn_Interval_Max. If provided, these data will be inserted into the advertising packet payload as AD data. These parameters are optional in this command. These values can be set in advertised data using GAP_Update_Adv_Data command separately. The total size of data in advertising packet cannot exceed 31 bytes. With this command, the BLE Stack will also add automatically the following standard AD types: - AD Flags - Power Level When advertising timeout happens (i.e. limited discovery period has elapsed), controller generates @ref aci_gap_limited_discoverable_event event. * @param Advertising_Type Advertising type. Advertising_Type type cannot be any of GAP_ADV_HIGH_DC_DIRECT_IND or GAP_ADV_HIGH_DC_DIRECT_IND. * Values: - 0x00: ADV_IND (Connectable undirected advertising) - 0x01: ADV_DIRECT_IND (Connectable directed advertising) - 0x02: ADV_SCAN_IND (Scannable undirected advertising) - 0x03: ADV_NONCONN_IND (Non connectable undirected advertising) * @param Advertising_Interval_Min Minimum advertising interval. Time = N * 0.625 msec. * Values: - 0x0020 (20.000 ms) ... 0x4000 (10240.000 ms) * @param Advertising_Interval_Max Maximum advertising interval. Time = N * 0.625 msec. * Values: - 0x0020 (20.000 ms) ... 0x4000 (10240.000 ms) * @param Own_Address_Type Own address type: - 0x00: Public Device Address (it is allowed only if privacy is disabled) - 0x01: Random Device Address (it is allowed only if privacy is disabled) - 0x02: Resolvable Private Address (it is allowed only if privacy is enabled) - 0x03: Non Resolvable Private Address (it is allowed only if privacy is enabled) * Values: - 0x00: Public Device Address - 0x01: Random Device Address - 0x02: Resolvable Private Address - 0x03: Non Resolvable Private Address * @param Advertising_Filter_Policy Advertising filter policy: not applicable (the value of Advertising_Filter_Policy parameter is not used inside the Stack) * @param Local_Name_Length Length of the local_name field in octets. If length is set to 0x00, Local_Name parameter is not used. * @param Local_Name Local name of the device. First byte must be 0x08 for Shortened Local Name or 0x09 for Complete Local Name. No NULL character at the end. * @param Service_Uuid_length Length of the Service Uuid List in octets. If there is no service to be advertised, set this field to 0x00. * @param Service_Uuid_List This is the list of the UUIDs as defined in Volume 3, Section 11 of GAP Specification. First byte is the AD Type. See also Supplement to the Bluetooth Core specification. * @param Slave_Conn_Interval_Min Slave connection interval minimum value suggested by Peripheral. If Slave_Conn_Interval_Min and Slave_Conn_Interval_Max are not 0x0000, Slave Connection Interval Range AD structure will be added in advertising data. Connection interval is defined in the following manner: connIntervalmin = Slave_Conn_Interval_Min x 1.25ms. * Values: - 0x0000 (NaN) - 0xFFFF (NaN) : No specific minimum - 0x0006 (7.50 ms) ... 0x0C80 (4000.00 ms) * @param Slave_Conn_Interval_Max Slave connection interval maximum value suggested by Peripheral. If Slave_Conn_Interval_Min and Slave_Conn_Interval_Max are not 0x0000, Slave Connection Interval Range AD structure will be added in advertising data. Connection interval is defined in the following manner: connIntervalmax = Slave_Conn_Interval_Max x 1.25ms * Values: - 0x0000 (NaN) - 0xFFFF (NaN) : No specific maximum - 0x0006 (7.50 ms) ... 0x0C80 (4000.00 ms) * @retval Value indicating success or error code. */ tBleStatus aci_gap_set_limited_discoverable(uint8_t Advertising_Type, uint16_t Advertising_Interval_Min, uint16_t Advertising_Interval_Max, uint8_t Own_Address_Type, uint8_t Advertising_Filter_Policy, uint8_t Local_Name_Length, uint8_t Local_Name[], uint8_t Service_Uuid_length, uint8_t Service_Uuid_List[], uint16_t Slave_Conn_Interval_Min, uint16_t Slave_Conn_Interval_Max); /** * @brief Put the device in general discoverable mode (as defined in Bluetooth Specification v.4.1, Vol. 3, Part C, section 9.2.4). The device will be discoverable until the host issues the @ref aci_gap_set_non_discoverable command. The Adv_Interval_Min and Adv_Interval_Max parameters are optional. If both are set to 0, the GAP uses the default values for adv intervals for general discoverable mode. When using connectable undirected advertising events: - Adv_Interval_Min = 30 ms - Adv_Interval_Max = 60 ms When using non-connectable advertising events or scannable undirected advertising events: - Adv_Interval_Min = 100 ms - Adv_Interval_Max = 150 ms Host can set the Local Name, a Service UUID list and the Slave Connection Interval Range. If provided, these data will be inserted into the advertising packet payload as AD data. These parameters are optional in this command. These values can be also set using aci_gap_update_adv_data() separately. The total size of data in advertising packet cannot exceed 31 bytes. With this command, the BLE Stack will also add automatically the following standard AD types: - AD Flags - TX Power Level * @param Advertising_Type Advertising type. Advertising_Type type cannot be any of GAP_ADV_HIGH_DC_DIRECT_IND or GAP_ADV_HIGH_DC_DIRECT_IND. * Values: - 0x00: ADV_IND (Connectable undirected advertising) - 0x01: ADV_DIRECT_IND (Connectable directed advertising) - 0x02: ADV_SCAN_IND (Scannable undirected advertising) - 0x03: ADV_NONCONN_IND (Non connectable undirected advertising) * @param Advertising_Interval_Min Minimum advertising interval. Time = N * 0.625 msec. * Values: - 0x0020 (20.000 ms) ... 0x4000 (10240.000 ms) * @param Advertising_Interval_Max Maximum advertising interval. Time = N * 0.625 msec. * Values: - 0x0020 (20.000 ms) ... 0x4000 (10240.000 ms) * @param Own_Address_Type Own address type: - 0x00: Public Device Address (it is allowed only if privacy is disabled) - 0x01: Random Device Address (it is allowed only if privacy is disabled) - 0x02: Resolvable Private Address (it is allowed only if privacy is enabled) - 0x03: Non Resolvable Private Address (it is allowed only if privacy is enabled) * Values: - 0x00: Public Device Address - 0x01: Random Device Address - 0x02: Resolvable Private Address - 0x03: Non Resolvable Private Address * @param Advertising_Filter_Policy Advertising filter policy: not applicable (the value of Advertising_Filter_Policy parameter is not used inside the Stack) * @param Local_Name_Length Length of the local_name field in octets. If length is set to 0x00, Local_Name parameter is not used. * @param Local_Name Local name of the device. First byte must be 0x08 for Shortened Local Name or 0x09 for Complete Local Name. No NULL character at the end. * @param Service_Uuid_length Length of the Service Uuid List in octets. If there is no service to be advertised, set this field to 0x00. * @param Service_Uuid_List This is the list of the UUIDs as defined in Volume 3, Section 11 of GAP Specification. First byte is the AD Type. See also Supplement to the Bluetooth Core specification. * @param Slave_Conn_Interval_Min Slave connection interval minimum value suggested by Peripheral. If Slave_Conn_Interval_Min and Slave_Conn_Interval_Max are not 0x0000, Slave Connection Interval Range AD structure will be added in advertising data. Connection interval is defined in the following manner: connIntervalmin = Slave_Conn_Interval_Min x 1.25ms. * Values: - 0x0000 (NaN) - 0xFFFF (NaN) : No specific minimum - 0x0006 (7.50 ms) ... 0x0C80 (4000.00 ms) * @param Slave_Conn_Interval_Max Slave connection interval maximum value suggested by Peripheral. If Slave_Conn_Interval_Min and Slave_Conn_Interval_Max are not 0x0000, Slave Connection Interval Range AD structure will be added in advertising data. Connection interval is defined in the following manner: connIntervalmax = Slave_Conn_Interval_Max x 1.25ms * Values: - 0x0000 (NaN) - 0xFFFF (NaN) : No specific maximum - 0x0006 (7.50 ms) ... 0x0C80 (4000.00 ms) * @retval Value indicating success or error code. */ tBleStatus aci_gap_set_discoverable(uint8_t Advertising_Type, uint16_t Advertising_Interval_Min, uint16_t Advertising_Interval_Max, uint8_t Own_Address_Type, uint8_t Advertising_Filter_Policy, uint8_t Local_Name_Length, uint8_t Local_Name[], uint8_t Service_Uuid_length, uint8_t Service_Uuid_List[], uint16_t Slave_Conn_Interval_Min, uint16_t Slave_Conn_Interval_Max); /** * @brief Set the device in direct connectable mode (as defined in Bluetooth Specification v.4.1, Vol. 3, Part C, section 9.3.3). Device uses direct connectable mode to advertise using High Duty cycle advertisement events or Low Duty cycle advertisement events and the address as either what is specified in the Own Address Type parameter. The command specifies the type of the advertising used. If the privacy is enabled, the Type parameter in reconnection address is used for advertising, otherwise the address of the type specified in OwnAddrType is used. The device will be in directed connectable mode only for 1.28 seconds. If no connection is established within this duration, the device enters non discoverable mode and advertising will have to be again enabled explicitly. The controller generates a @ref hci_le_connection_complete_event event with the status set to 0x3C (Directed Advertising Timeout) if the connection was not established and 0x00 if the connection was successfully established. If Host privacy (i.e. privacy 1.1) is enabled this command returns BLE_STATUS_INVALID_PARAMS. * @param Own_Address_Type Own address type: - 0x00: Public Device Address (only if privacy is disabled) - 0x01: Random Device Address (only if privacy is disabled) - 0x02: Resolvable Private Address (only if privacy is enabled) * Values: - 0x00: Public Device Address - 0x01: Random Device Address - 0x02: Resolvable Private Address * @param Directed_Advertising_Type Type of directed advertising. * Values: - 0x01: High Duty Cycle Directed Advertising - 0x04: Low Duty Cycle Directed Advertising * @param Direct_Address_Type Peer Address type. * Values: - 0x00: Public Device Address or Public Identity Address - 0x01: Random Device Address or Random (static) Identity Address * @param Direct_Address Initiator Bluetooth address * @param Advertising_Interval_Min Minimum advertising interval. Time = N * 0.625 msec. * Values: - 0x0020 (20.000 ms) ... 0x4000 (10240.000 ms) * @param Advertising_Interval_Max Maximum advertising interval. Time = N * 0.625 msec. * Values: - 0x0020 (20.000 ms) ... 0x4000 (10240.000 ms) * @retval Value indicating success or error code. */ tBleStatus aci_gap_set_direct_connectable(uint8_t Own_Address_Type, uint8_t Directed_Advertising_Type, uint8_t Direct_Address_Type, uint8_t Direct_Address[6], uint16_t Advertising_Interval_Min, uint16_t Advertising_Interval_Max); /** * @brief Set the IO capabilities of the device. This command has to be given only when the device is not in a connected state. * @param IO_Capability IO capability of the device. * Values: - 0x00: IO_CAP_DISPLAY_ONLY - 0x01: IO_CAP_DISPLAY_YES_NO - 0x02: IO_CAP_KEYBOARD_ONLY - 0x03: IO_CAP_NO_INPUT_NO_OUTPUT - 0x04: IO_CAP_KEYBOARD_DISPLAY * @retval Value indicating success or error code. */ tBleStatus aci_gap_set_io_capability(uint8_t IO_Capability); /** * @brief Set the authentication requirements for the device. This command has to be given only when the device is not in a connected state. * @param Bonding_Mode Bonding mode. Only if bonding is enabled (0x01), the bonding information is stored in flash * Values: - 0x00: No-bonding mode - 0x01: Bonding mode * @param MITM_Mode MITM mode. * Values: - 0x00: MITM protection not required - 0x01: MITM protection required * @param SC_Support LE Secure connections support * Values: - 0x00: Secure Connections Pairing not supported - 0x01: Secure Connections Pairing supported but optional - 0x02: Secure Connections Pairing supported and mandatory (SC Only Mode) * @param KeyPress_Notification_Support Keypress notification support * Values: - 0x00: Keypress notification not supported - 0x01: Keypress notification supported * @param Min_Encryption_Key_Size Minimum encryption key size to be used during pairing * @param Max_Encryption_Key_Size Maximum encryption key size to be used during pairing * @param Use_Fixed_Pin Use or not fixed pin. If set to 0x00, then during the pairing process the application will not be requested for a pin (Fixed_Pin will be used). If set to 0x01, then during pairing process if a passkey is required the application will be notified * Values: - 0x00: use a fixed pin - 0x01: do not use a fixed pin * @param Fixed_Pin Fixed pin to be used during pairing if MIMT protection is enabled. Any random value between 0 to 999999 * Values: - 0 ... 999999 * @param Identity_Address_Type Identity address type. * Values: - 0x00: Public Identity Address - 0x01: Random (static) Identity Address * @retval Value indicating success or error code. */ tBleStatus aci_gap_set_authentication_requirement(uint8_t Bonding_Mode, uint8_t MITM_Mode, uint8_t SC_Support, uint8_t KeyPress_Notification_Support, uint8_t Min_Encryption_Key_Size, uint8_t Max_Encryption_Key_Size, uint8_t Use_Fixed_Pin, uint32_t Fixed_Pin, uint8_t Identity_Address_Type); /** * @brief Set the authorization requirements of the device. This command has to be given when connected to a device if authorization is required to access services which require authorization. * @param Connection_Handle Connection handle for which the command is given. * Values: - 0x0000 ... 0x0EFF * @param Authorization_Enable Enable the authorization in the device and when a remote device tries to read/write a characteristic with authorization requirements, the stack will send back an error response with "Insufficient authorization" error code. After pairing is complete a ACI_GAP_AUTHORIZATION_REQ_EVENT will be sent to the Host. * Values: - 0x00: Authorization not required - 0x01: Authorization required * @retval Value indicating success or error code. */ tBleStatus aci_gap_set_authorization_requirement(uint16_t Connection_Handle, uint8_t Authorization_Enable); /** * @brief This command should be send by the host in response to @ref aci_gap_pass_key_req_event event. The command parameter contains the pass key which will be used during the pairing process. * @param Connection_Handle Connection handle for which the command is given. * Values: - 0x0000 ... 0x0EFF * @param Pass_Key Pass key that will be used during the pairing process. Must be a six-digit decimal number. * Values: - 0 ... 999999 * @retval Value indicating success or error code. */ tBleStatus aci_gap_pass_key_resp(uint16_t Connection_Handle, uint32_t Pass_Key); /** * @brief Authorize a device to access attributes. This command should be send by the host in response to @ref aci_gap_authorization_req_event event. * @param Connection_Handle Connection handle for which the command is given. * Values: - 0x0000 ... 0x0EFF * @param Authorize Authorization response. * Values: - 0x01: Authorize - 0x02: Reject * @retval Value indicating success or error code. */ tBleStatus aci_gap_authorization_resp(uint16_t Connection_Handle, uint8_t Authorize); /** * @brief Initialize the GAP layer. Register the GAP service with the GATT. All the standard GAP characteristics will also be added: - Device Name - Appearance - Peripheral Preferred Connection Parameters (peripheral role only) * @param Role Bitmap of allowed roles. * Flags: - 0x01: Peripheral - 0x02: Broadcaster - 0x04: Central - 0x08: Observer * @param privacy_enabled Specify if privacy is enabled or not and which one . * Values: - 0x00: Privacy disabled - 0x01: Privacy host enabled - 0x02: Privacy controller enabled * @param device_name_char_len Length of the device name characteristic * @param[out] Service_Handle Handle of the GAP service * @param[out] Dev_Name_Char_Handle Device Name Characteristic handle * @param[out] Appearance_Char_Handle Appearance Characteristic handle * @retval Value indicating success or error code. */ tBleStatus aci_gap_init(uint8_t Role, uint8_t privacy_enabled, uint8_t device_name_char_len, uint16_t *Service_Handle, uint16_t *Dev_Name_Char_Handle, uint16_t *Appearance_Char_Handle); /** * @brief Put the device into non connectable mode. This mode does not support connection. The privacy setting done in the @ref aci_gap_init command plays a role in deciding the valid parameters for this command. Advertiser filter policy is internally set to 0x00 * @param Advertising_Event_Type Advertising type. * Values: - 0x02: ADV_SCAN_IND (Scannable undirected advertising) - 0x03: ADV_NONCONN_IND (Non connectable undirected advertising) * @param Own_Address_Type Own address type: - 0x00: Public Device Address (it is allowed only if privacy is disabled) - 0x01: Random Device Address (it is allowed only if privacy is disabled) - 0x02: Resolvable Private Address (it is allowed only if privacy is enabled) - 0x03: Non Resolvable Private Address (it is allowed only if privacy is enabled) * Values: - 0x00: Public Device Address - 0x01: Random Device Address - 0x02: Resolvable Private Address - 0x03: Non Resolvable Private Address * @retval Value indicating success or error code. */ tBleStatus aci_gap_set_non_connectable(uint8_t Advertising_Event_Type, uint8_t Own_Address_Type); /** * @brief Put the device into undirected connectable mode. If privacy is enabled in the device, a resolvable private address is generated and used as the advertiser's address. If not, the address of the type specified in own_addr_type is used for advertising. * @param Advertising_Interval_Min Minimum advertising interval. Time = N * 0.625 msec. * Values: - 0x0020 (20.000 ms) ... 0x4000 (10240.000 ms) * @param Advertising_Interval_Max Maximum advertising interval. Time = N * 0.625 msec. * Values: - 0x0020 (20.000 ms) ... 0x4000 (10240.000 ms) * @param Own_Address_Type Own address type: - 0x00: Public Device Address (it is allowed only if privacy is disabled) - 0x01: Random Device Address (it is allowed only if privacy is disabled) - 0x02: Resolvable Private Address (it is allowed only if controller privacy is enabled or if Host privacy (i.e. privacy 1.1) is enabled) - 0x03: Non Resolvable Private Address (it is allowed only if Host privacy (i.e. privacy 1.1) is enabled) * Values: - 0x00: Public Device Address - 0x01: Random Device Address - 0x02: Resolvable Private Address - 0x03: Non Resolvable Private Address * @param Adv_Filter_Policy Advertising filter policy. * Values: - 0x00: Allow Scan Request from Any, Allow Connect Request from Any - 0x03: Allow Scan Request from White List Only, Allow Connect Request from White List Only * @retval Value indicating success or error code. */ tBleStatus aci_gap_set_undirected_connectable(uint16_t Advertising_Interval_Min, uint16_t Advertising_Interval_Max, uint8_t Own_Address_Type, uint8_t Adv_Filter_Policy); /** * @brief Send a slave security request to the master. This command has to be issued to notify the master of the security requirements of the slave. The master may encrypt the link, initiate the pairing procedure, or reject the request. * @param Connection_Handle Connection handle for which the command is given. * Values: - 0x0000 ... 0x0EFF * @retval Value indicating success or error code. */ tBleStatus aci_gap_slave_security_req(uint16_t Connection_Handle); /** * @brief This command can be used to update the advertising data for a particular AD type. If the AD type specified does not exist, then it is added to the advertising data. If the overall advertising data length is more than 31 octets after the update, then the command is rejected and the old data is retained. * @param AdvDataLen Length of AdvData in octets * @param AdvData Advertising data used by the device while advertising. * @retval Value indicating success or error code. */ tBleStatus aci_gap_update_adv_data(uint8_t AdvDataLen, uint8_t AdvData[]); /** * @brief This command can be used to delete the specified AD type from the advertisement data if present. * @param ADType One of the AD types like in Bluetooth specification (see volume 3, Part C, 11.1) * @retval Value indicating success or error code. */ tBleStatus aci_gap_delete_ad_type(uint8_t ADType); /** * @brief This command can be used to get the current security settings of the device. * @param Connection_Handle Connection handle for which the command is given. * Values: - 0x0000 ... 0x0EFF * @param[out] Security_Mode Security mode. * Values: - 0x01: Security Mode 1 - 0x02: Security Mode 2 * @param[out] Security_Level Security Level. * Values: - 0x01: Security Level 1 - 0x02: Security Level 2 - 0x03: Security Level 3 - 0x04: Security Level 4 * @retval Value indicating success or error code. */ tBleStatus aci_gap_get_security_level(uint16_t Connection_Handle, uint8_t *Security_Mode, uint8_t *Security_Level); /** * @brief It allows masking events from the GAP. The default configuration is all the events masked. * @param GAP_Evt_Mask GAP event mask. Default: 0xFFFF. * Flags: - 0x0000: No events - 0x0001: ACI_GAP_LIMITED_DISCOVERABLE_EVENT - 0x0002: ACI_GAP_PAIRING_COMPLETE_EVENT - 0x0004: ACI_GAP_PASS_KEY_REQ_EVENT - 0x0008: ACI_GAP_AUTHORIZATION_REQ_EVENT - 0x0010: ACI_GAP_SLAVE_SECURITY_INITIATED_EVENT - 0x0020: ACI_GAP_BOND_LOST_EVENT - 0x0080: ACI_GAP_PROC_COMPLETE_EVENT - 0x0100: ACI_L2CAP_CONNECTION_UPDATE_REQ_EVENT - 0x0200: ACI_L2CAP_CONNECTION_UPDATE_RESP_EVENT - 0x0400: ACI_L2CAP_PROC_TIMEOUT_EVENT - 0x0800: ACI_GAP_ADDR_NOT_RESOLVED_EVENT * @retval Value indicating success or error code. */ tBleStatus aci_gap_set_event_mask(uint16_t GAP_Evt_Mask); /** * @brief Add addresses of bonded devices into the controller's whitelist. The command will return an error if there are no devices in the database or if it was unable to add the device into the whitelist. * @retval Value indicating success or error code. */ tBleStatus aci_gap_configure_whitelist(void); /** * @brief Command the controller to terminate the connection. A @ref hci_disconnection_complete_event event will be generated when the link is disconnected. It is important to leave an 100 ms blank window before sending any new command (including system hardware reset), since immediately after @ref hci_disconnection_complete_event event, system could save important information in non volatile memory. * @param Connection_Handle Connection handle for which the command is given. * Values: - 0x0000 ... 0x0EFF * @param Reason The reason for ending the connection. * Values: - 0x05: Authentication Failure - 0x13: Remote User Terminated Connection - 0x14: Remote Device Terminated Connection due to Low Resources - 0x15: Remote Device Terminated Connection due to Power Off - 0x1A: Unsupported Remote Feature - 0x3B: Unacceptable Connection Parameters * @retval Value indicating success or error code. */ tBleStatus aci_gap_terminate(uint16_t Connection_Handle, uint8_t Reason); /** * @brief Clear the security database. All the devices in the security database will be removed. * @retval Value indicating success or error code. */ tBleStatus aci_gap_clear_security_db(void); /** * @brief Allows the security manager to complete the pairing procedure and re-bond with the master. This command should be given by the application when it receives the ACI_GAP_BOND_LOST_EVENT if it wants the re-bonding to happen successfully. If this command is not given on receiving the event, the bonding procedure will timeout. * @param Connection_Handle Connection handle for which the command is given. * Values: - 0x0000 ... 0x0EFF * @retval Value indicating success or error code. */ tBleStatus aci_gap_allow_rebond(uint16_t Connection_Handle); /** * @brief Start the limited discovery procedure. The controller is commanded to start active scanning. When this procedure is started, only the devices in limited discoverable mode are returned to the upper layers. The procedure is terminated when either the upper layers issue a command to terminate the procedure by issuing the command @ref aci_gap_terminate_gap_proc with the procedure code set to 0x01 or a timeout happens. When the procedure is terminated due to any of the above reasons, @ref aci_gap_proc_complete_event event is returned with the procedure code set to 0x01. The device found when the procedure is ongoing is returned to the upper layers through the event @ref hci_le_advertising_report_event. * @param LE_Scan_Interval This is defined as the time interval from when the Controller started its last LE scan until it begins the subsequent LE scan. Time = N * 0.625 msec. * Values: - 0x0004 (2.500 ms) ... 0x4000 (10240.000 ms) * @param LE_Scan_Window Amount of time for the duration of the LE scan. LE_Scan_Window shall be less than or equal to LE_Scan_Interval. Time = N * 0.625 msec. * Values: - 0x0004 (2.500 ms) ... 0x4000 (10240.000 ms) * @param Own_Address_Type Own address type: - 0x00: Public Device Address (it is allowed only if privacy is disabled) - 0x01: Random Device Address (it is allowed only if privacy is disabled) - 0x02: Resolvable Private Address (it is allowed only if privacy is enabled) - 0x03: Non Resolvable Private Address (it is allowed only if privacy is enabled) * Values: - 0x00: Public Device Address - 0x01: Random Device Address - 0x02: Resolvable Private Address - 0x03: Non Resolvable Private Address * @param Filter_Duplicates Enable/disable duplicate filtering. * Values: - 0x00: Duplicate filtering disabled - 0x01: Duplicate filtering enabled * @retval Value indicating success or error code. */ tBleStatus aci_gap_start_limited_discovery_proc(uint16_t LE_Scan_Interval, uint16_t LE_Scan_Window, uint8_t Own_Address_Type, uint8_t Filter_Duplicates); /** * @brief Start the general discovery procedure. The controller is commanded to start active scanning. The procedure is terminated when either the upper layers issue a command to terminate the procedure by issuing the command @ref aci_gap_terminate_gap_proc with the procedure code set to 0x02 or a timeout happens. When the procedure is terminated due to any of the above reasons, @ref aci_gap_proc_complete_event event is returned with the procedure code set to 0x02. The device found when the procedure is ongoing is returned to @ref hci_le_advertising_report_event. * @param LE_Scan_Interval This is defined as the time interval from when the Controller started its last LE scan until it begins the subsequent LE scan. Time = N * 0.625 msec. * Values: - 0x0004 (2.500 ms) ... 0x4000 (10240.000 ms) * @param LE_Scan_Window Amount of time for the duration of the LE scan. LE_Scan_Window shall be less than or equal to LE_Scan_Interval. Time = N * 0.625 msec. * Values: - 0x0004 (2.500 ms) ... 0x4000 (10240.000 ms) * @param Own_Address_Type Own address type: - 0x00: Public Device Address (it is allowed only if privacy is disabled) - 0x01: Random Device Address (it is allowed only if privacy is disabled) - 0x02: Resolvable Private Address (it is allowed only if privacy is enabled) - 0x03: Non Resolvable Private Address (it is allowed only if privacy is enabled) * Values: - 0x00: Public Device Address - 0x01: Random Device Address - 0x02: Resolvable Private Address - 0x03: Non Resolvable Private Address * @param Filter_Duplicates Enable/disable duplicate filtering. * Values: - 0x00: Duplicate filtering disabled - 0x01: Duplicate filtering enabled * @retval Value indicating success or error code. */ tBleStatus aci_gap_start_general_discovery_proc(uint16_t LE_Scan_Interval, uint16_t LE_Scan_Window, uint8_t Own_Address_Type, uint8_t Filter_Duplicates); /** * @brief Start the name discovery procedure. A LE_Create_Connection call will be made to the controller by GAP with the initiator filter policy set to "ignore whitelist and process connectable advertising packets only for the specified device". Once a connection is established, GATT procedure is started to read the device name characteristic. When the read is completed (successfully or unsuccessfully), a @ref aci_gap_proc_complete_event event is given to the upper layer. The event also contains the name of the device if the device name was read successfully. * @param LE_Scan_Interval This is defined as the time interval from when the Controller started its last LE scan until it begins the subsequent LE scan. Time = N * 0.625 msec. * Values: - 0x0004 (2.500 ms) ... 0x4000 (10240.000 ms) * @param LE_Scan_Window Amount of time for the duration of the LE scan. LE_Scan_Window shall be less than or equal to LE_Scan_Interval. Time = N * 0.625 msec. * Values: - 0x0004 (2.500 ms) ... 0x4000 (10240.000 ms) * @param Peer_Address_Type Address type. * Values: - 0x00: Public Device Address - 0x01: Random Device Address * @param Peer_Address Public Device Address, Random Device Address, Public Identity Address or Random (static) Identity Address of the advertising device. * @param Own_Address_Type Own address type: - 0x00: Public Device Address (it is allowed only if privacy is disabled) - 0x01: Random Device Address (it is allowed only if privacy is disabled) - 0x02: Resolvable Private Address (it is allowed only if privacy is enabled) - 0x03: Non Resolvable Private Address (it is allowed only if privacy is enabled) * Values: - 0x00: Public Device Address - 0x01: Random Device Address - 0x02: Resolvable Private Address - 0x03: Non Resolvable Private Address * @param Conn_Interval_Min Minimum value for the connection event interval. This shall be less than or equal to Conn_Interval_Max. Time = N * 1.25 msec. * Values: - 0x0006 (7.50 ms) ... 0x0C80 (4000.00 ms) * @param Conn_Interval_Max Maximum value for the connection event interval. This shall be greater than or equal to Conn_Interval_Min. Time = N * 1.25 msec. * Values: - 0x0006 (7.50 ms) ... 0x0C80 (4000.00 ms) * @param Conn_Latency Slave latency for the connection in number of connection events. * Values: - 0x0000 ... 0x01F3 * @param Supervision_Timeout Supervision timeout for the LE Link. It shall be a multiple of 10 ms and larger than (1 + connSlaveLatency) * connInterval * 2. Time = N * 10 msec. * Values: - 0x000A (100 ms) ... 0x0C80 (32000 ms) * @param Minimum_CE_Length Information parameter about the minimum length of connection needed for this LE connection. Time = N * 0.625 msec. * @param Maximum_CE_Length Information parameter about the maximum length of connection needed for this LE connection. Time = N * 0.625 msec. * @retval Value indicating success or error code. */ tBleStatus aci_gap_start_name_discovery_proc(uint16_t LE_Scan_Interval, uint16_t LE_Scan_Window, uint8_t Peer_Address_Type, uint8_t Peer_Address[6], uint8_t Own_Address_Type, uint16_t Conn_Interval_Min, uint16_t Conn_Interval_Max, uint16_t Conn_Latency, uint16_t Supervision_Timeout, uint16_t Minimum_CE_Length, uint16_t Maximum_CE_Length); /** * @brief Start the auto connection establishment procedure. The devices specified are added to the white list of the controller and a LE_Create_Connection call will be made to the controller by GAP with the initiator filter policy set to "use whitelist to determine which advertiser to connect to". When a command is issued to terminate the procedure by upper layer, a LE_Create_Connection_Cancel call will be made to the controller by GAP. The procedure is terminated when either a connection is successfully established with one of the specified devices in the white list or the procedure is explicitly terminated by issuing the command @ref aci_gap_terminate_gap_proc with the procedure code set to 0x08. A @ref aci_gap_proc_complete_event event is returned with the procedure code set to 0x08. If controller privacy is enabled and the peer device (advertiser) is in the resolving list then the link layer will generate a RPA, if it is not then the RPA/NRPA generated by the Host will be used. * @param LE_Scan_Interval This is defined as the time interval from when the Controller started its last LE scan until it begins the subsequent LE scan. Time = N * 0.625 msec. * Values: - 0x0004 (2.500 ms) ... 0x4000 (10240.000 ms) * @param LE_Scan_Window Amount of time for the duration of the LE scan. LE_Scan_Window shall be less than or equal to LE_Scan_Interval. Time = N * 0.625 msec. * Values: - 0x0004 (2.500 ms) ... 0x4000 (10240.000 ms) * @param Own_Address_Type Own address type: - 0x00: Public Device Address (it is allowed only if privacy is disabled) - 0x01: Random Device Address (it is allowed only if privacy is disabled) - 0x02: Resolvable Private Address (it is allowed only if privacy is enabled) - 0x03: Non Resolvable Private Address (it is allowed only if privacy is enabled) * Values: - 0x00: Public Device Address - 0x01: Random Device Address - 0x02: Resolvable Private Address - 0x03: Non Resolvable Private Address * @param Conn_Interval_Min Minimum value for the connection event interval. This shall be less than or equal to Conn_Interval_Max. Time = N * 1.25 msec. * Values: - 0x0006 (7.50 ms) ... 0x0C80 (4000.00 ms) * @param Conn_Interval_Max Maximum value for the connection event interval. This shall be greater than or equal to Conn_Interval_Min. Time = N * 1.25 msec. * Values: - 0x0006 (7.50 ms) ... 0x0C80 (4000.00 ms) * @param Conn_Latency Slave latency for the connection in number of connection events. * Values: - 0x0000 ... 0x01F3 * @param Supervision_Timeout Supervision timeout for the LE Link. It shall be a multiple of 10 ms and larger than (1 + connSlaveLatency) * connInterval * 2. Time = N * 10 msec. * Values: - 0x000A (100 ms) ... 0x0C80 (32000 ms) * @param Minimum_CE_Length Information parameter about the minimum length of connection needed for this LE connection. Time = N * 0.625 msec. * @param Maximum_CE_Length Information parameter about the maximum length of connection needed for this LE connection. Time = N * 0.625 msec. * @param Num_of_Whitelist_Entries Number of devices that have to be added to the whitelist. * @param Whitelist_Entry See @ref Whitelist_Entry_t * @retval Value indicating success or error code. */ tBleStatus aci_gap_start_auto_connection_establish_proc(uint16_t LE_Scan_Interval, uint16_t LE_Scan_Window, uint8_t Own_Address_Type, uint16_t Conn_Interval_Min, uint16_t Conn_Interval_Max, uint16_t Conn_Latency, uint16_t Supervision_Timeout, uint16_t Minimum_CE_Length, uint16_t Maximum_CE_Length, uint8_t Num_of_Whitelist_Entries, Whitelist_Entry_t Whitelist_Entry[]); /** * @brief Start a general connection establishment procedure. The host enables scanning in the controller with the scanner filter policy set to "accept all advertising packets" and from the scanning results, all the devices are sent to the upper layer using the event LE_Advertising_Report. The upper layer then has to select one of the devices to which it wants to connect by issuing the command @ref aci_gap_create_connection. If privacy is enabled, then either a private resolvable address or a non resolvable address, based on the address type specified in the command is set as the scanner address but the gap create connection always uses a private resolvable address if the general connection establishment procedure is active. The procedure is terminated when a connection is established or the upper layer terminates the procedure by issuing the command @ref aci_gap_terminate_gap_proc with the procedure code set to 0x10. On completion of the procedure a @ref aci_gap_proc_complete_event event is generated with the procedure code set to 0x10. If controller privacy is enabled and the peer device (advertiser) is in the resolving list then the link layer will generate a RPA, if it is not then the RPA/NRPA generated by the Host will be used. * @param LE_Scan_Type Passive or active scanning. With active scanning SCAN_REQ packets are sent. * Values: - 0x00: Passive Scanning - 0x01: Active scanning * @param LE_Scan_Interval This is defined as the time interval from when the Controller started its last LE scan until it begins the subsequent LE scan. Time = N * 0.625 msec. * Values: - 0x0004 (2.500 ms) ... 0x4000 (10240.000 ms) * @param LE_Scan_Window Amount of time for the duration of the LE scan. LE_Scan_Window shall be less than or equal to LE_Scan_Interval. Time = N * 0.625 msec. * Values: - 0x0004 (2.500 ms) ... 0x4000 (10240.000 ms) * @param Own_Address_Type Own address type: - 0x00: Public Device Address (it is allowed only if privacy is disabled) - 0x01: Random Device Address (it is allowed only if privacy is disabled) - 0x02: Resolvable Private Address (it is allowed only if privacy is enabled) - 0x03: Non Resolvable Private Address (it is allowed only if privacy is enabled) * Values: - 0x00: Public Device Address - 0x01: Random Device Address - 0x02: Resolvable Private Address - 0x03: Non Resolvable Private Address * @param Scanning_Filter_Policy Scanning filter policy: - 0x00 Accept all advertisement packets.Directed advertising packets which are not addressed for this device shall be ignored. - 0x01 Ignore advertisement packets from devices not in the White List Only.Directed advertising packets which are not addressed for this device shall be ignored. - 0x02 Accept all undirected advertisement packets (it is allowed only if controller privacy or host privacy is enabled).Directed advertisement packets where initiator address is a RPA and Directed advertisement packets addressed to this device shall be accepted. - 0x03 Accept all undirected advertisement packets from devices that are in the White List.Directed advertisement packets where initiator address is RPA and Directed advertisement packets addressed to this device shall be accepted. - NOTE: if controller privacy is enabled Scanning_Filter_Policy can only assume values 0x00 or 0x02; if Host privacy is enabled Scanning_Filter_Policy can only assume value 0x00. * Values: - 0x00: Accept all - 0x01: Ignore devices not in the White List - 0x02: Accept all (use resolving list) - 0x03: Ignore devices not in the White List (use resolving list) * @param Filter_Duplicates Enable/disable duplicate filtering. * Values: - 0x00: Duplicate filtering disabled - 0x01: Duplicate filtering enabled * @retval Value indicating success or error code. */ tBleStatus aci_gap_start_general_connection_establish_proc(uint8_t LE_Scan_Type, uint16_t LE_Scan_Interval, uint16_t LE_Scan_Window, uint8_t Own_Address_Type, uint8_t Scanning_Filter_Policy, uint8_t Filter_Duplicates); /** * @brief Start a selective connection establishment procedure. The GAP adds the specified device addresses into white list and enables scanning in the controller with the scanner filter policy set to "accept packets only from devices in whitelist". All the devices found are sent to the upper layer by the event @ref hci_le_advertising_report_event. The upper layer then has to select one of the devices to which it wants to connect by issuing the command @ref aci_gap_create_connection. On completion of the procedure a @ref aci_gap_proc_complete_event event is generated with the procedure code set to 0x20. The procedure is terminated when a connection is established or the upper layer terminates the procedure by issuing the command @ref aci_gap_terminate_gap_proc with the procedure code set to 0x20. If controller privacy is enabled and the peer device (advertiser) is in the resolving list then the link layer will generate a RPA, if it is not then the RPA/NRPA generated by the Host will be used. * @param LE_Scan_Type Passive or active scanning. With active scanning SCAN_REQ packets are sent. * Values: - 0x00: Passive Scanning - 0x01: Active scanning * @param LE_Scan_Interval This is defined as the time interval from when the Controller started its last LE scan until it begins the subsequent LE scan. Time = N * 0.625 msec. * Values: - 0x0004 (2.500 ms) ... 0x4000 (10240.000 ms) * @param LE_Scan_Window Amount of time for the duration of the LE scan. LE_Scan_Window shall be less than or equal to LE_Scan_Interval. Time = N * 0.625 msec. * Values: - 0x0004 (2.500 ms) ... 0x4000 (10240.000 ms) * @param Own_Address_Type Own address type: - 0x00: Public Device Address (it is allowed only if privacy is disabled) - 0x01: Random Device Address (it is allowed only if privacy is disabled) - 0x02: Resolvable Private Address (it is allowed only if privacy is enabled) - 0x03: Non Resolvable Private Address (it is allowed only if privacy is enabled) * Values: - 0x00: Public Device Address - 0x01: Random Device Address - 0x02: Resolvable Private Address - 0x03: Non Resolvable Private Address * @param Scanning_Filter_Policy Scanning filter policy: - 0x00 Accept all advertisement packets.Directed advertising packets which are not addressed for this device shall be ignored. - 0x01 Ignore advertisement packets from devices not in the White List Only.Directed advertising packets which are not addressed for this device shall be ignored. - 0x02 Accept all undirected advertisement packets (it is allowed only if controller privacy or host privacy is enabled).Directed advertisement packets where initiator address is a RPA and Directed advertisement packets addressed to this device shall be accepted. - 0x03 Accept all undirected advertisement packets from devices that are in the White List.Directed advertisement packets where initiator address is RPA and Directed advertisement packets addressed to this device shall be accepted. - NOTE: if controller privacy is enabled Scanning_Filter_Policy can only assume values 0x01 or 0x03; if Host privacy is enabled Scanning_Filter_Policy can only assume value 0x01. * Values: - 0x00: Accept all - 0x01: Ignore devices not in the White List - 0x02: Accept all (use resolving list) - 0x03: Ignore devices not in the White List (use resolving list) * @param Filter_Duplicates Enable/disable duplicate filtering. * Values: - 0x00: Duplicate filtering disabled - 0x01: Duplicate filtering enabled * @param Num_of_Whitelist_Entries Number of devices that have to be added to the whitelist. * @param Whitelist_Entry See @ref Whitelist_Entry_t * @retval Value indicating success or error code. */ tBleStatus aci_gap_start_selective_connection_establish_proc(uint8_t LE_Scan_Type, uint16_t LE_Scan_Interval, uint16_t LE_Scan_Window, uint8_t Own_Address_Type, uint8_t Scanning_Filter_Policy, uint8_t Filter_Duplicates, uint8_t Num_of_Whitelist_Entries, Whitelist_Entry_t Whitelist_Entry[]); /** * @brief Start the direct connection establishment procedure. A LE_Create_Connection call will be made to the controller by GAP with the initiator filter policy set to "ignore whitelist and process connectable advertising packets only for the specified device". The procedure can be terminated explicitly by the upper layer by issuing the command @ref aci_gap_terminate_gap_proc. When a command is issued to terminate the procedure by upper layer, a @ref hci_le_create_connection_cancel call will be made to the controller by GAP. On termination of the procedure, a @ref hci_le_connection_complete_event event is returned. The procedure can be explicitly terminated by the upper layer by issuing the command @ref aci_gap_terminate_gap_proc with the procedure_code set to 0x40. If controller privacy is enabled and the peer device (advertiser) is in the resolving list then the link layer will generate a RPA, if it is not then the RPA/NRPA generated by the Host will be used. * @param LE_Scan_Interval This is defined as the time interval from when the Controller started its last LE scan until it begins the subsequent LE scan. Time = N * 0.625 msec. * Values: - 0x0004 (2.500 ms) ... 0x4000 (10240.000 ms) * @param LE_Scan_Window Amount of time for the duration of the LE scan. LE_Scan_Window shall be less than or equal to LE_Scan_Interval. Time = N * 0.625 msec. * Values: - 0x0004 (2.500 ms) ... 0x4000 (10240.000 ms) * @param Peer_Address_Type Peer Address type. * Values: - 0x00: Public Device Address or Public Identity Address - 0x01: Random Device Address or Random (static) Identity Address * @param Peer_Address Public Device Address, Random Device Address, Public Identity Address or Random (static) Identity Address of the advertising device. * @param Own_Address_Type Own address type: - 0x00: Public Device Address (it is allowed only if privacy is disabled) - 0x01: Random Device Address (it is allowed only if privacy is disabled) - 0x02: Resolvable Private Address (it is allowed only if privacy is enabled) - 0x03: Non Resolvable Private Address (it is allowed only if privacy is enabled) * Values: - 0x00: Public Device Address - 0x01: Random Device Address - 0x02: Resolvable Private Address - 0x03: Non Resolvable Private Address * @param Conn_Interval_Min Minimum value for the connection event interval. This shall be less than or equal to Conn_Interval_Max. Time = N * 1.25 msec. * Values: - 0x0006 (7.50 ms) ... 0x0C80 (4000.00 ms) * @param Conn_Interval_Max Maximum value for the connection event interval. This shall be greater than or equal to Conn_Interval_Min. Time = N * 1.25 msec. * Values: - 0x0006 (7.50 ms) ... 0x0C80 (4000.00 ms) * @param Conn_Latency Slave latency for the connection in number of connection events. * Values: - 0x0000 ... 0x01F3 * @param Supervision_Timeout Supervision timeout for the LE Link. It shall be a multiple of 10 ms and larger than (1 + connSlaveLatency) * connInterval * 2. Time = N * 10 msec. * Values: - 0x000A (100 ms) ... 0x0C80 (32000 ms) * @param Minimum_CE_Length Information parameter about the minimum length of connection needed for this LE connection. Time = N * 0.625 msec. * @param Maximum_CE_Length Information parameter about the maximum length of connection needed for this LE connection. Time = N * 0.625 msec. * @retval Value indicating success or error code. */ tBleStatus aci_gap_create_connection(uint16_t LE_Scan_Interval, uint16_t LE_Scan_Window, uint8_t Peer_Address_Type, uint8_t Peer_Address[6], uint8_t Own_Address_Type, uint16_t Conn_Interval_Min, uint16_t Conn_Interval_Max, uint16_t Conn_Latency, uint16_t Supervision_Timeout, uint16_t Minimum_CE_Length, uint16_t Maximum_CE_Length); /** * @brief Terminate the specified GATT procedure. An @ref aci_gap_proc_complete_event event is returned with the procedure code set to the corresponding procedure. * @param Procedure_Code GAP procedure bitmap. * Values: - 0x00: No events - 0x01: LIMITED_DISCOVERY_PROC - 0x02: GENERAL_DISCOVERY_PROC - 0x04: NAME_DISCOVERY_PROC - 0x08: AUTO_CONNECTION_ESTABLISHMENT_PROC - 0x10: GENERAL_CONNECTION_ESTABLISHMENT_PROC - 0x20: SELECTIVE_CONNECTION_ESTABLISHMENT_PROC - 0x40: DIRECT_CONNECTION_ESTABLISHMENT_PROC - 0x80: OBSERVATION_PROC * @retval Value indicating success or error code. */ tBleStatus aci_gap_terminate_gap_proc(uint8_t Procedure_Code); /** * @brief Start the connection update procedure (only when role is Master). A @ref hci_le_connection_update is called. On completion of the procedure, an @ref hci_le_connection_update_complete_event event is returned to the upper layer. * @param Connection_Handle Connection handle for which the command is given. * Values: - 0x0000 ... 0x0EFF * @param Conn_Interval_Min Minimum value for the connection event interval. This shall be less than or equal to Conn_Interval_Max. Time = N * 1.25 msec. * Values: - 0x0006 (7.50 ms) ... 0x0C80 (4000.00 ms) * @param Conn_Interval_Max Maximum value for the connection event interval. This shall be greater than or equal to Conn_Interval_Min. Time = N * 1.25 msec. * Values: - 0x0006 (7.50 ms) ... 0x0C80 (4000.00 ms) * @param Conn_Latency Slave latency for the connection in number of connection events. * Values: - 0x0000 ... 0x01F3 * @param Supervision_Timeout Supervision timeout for the LE Link. It shall be a multiple of 10 ms and larger than (1 + connSlaveLatency) * connInterval * 2. Time = N * 10 msec. * Values: - 0x000A (100 ms) ... 0x0C80 (32000 ms) * @param Minimum_CE_Length Information parameter about the minimum length of connection needed for this LE connection. Time = N * 0.625 msec. * @param Maximum_CE_Length Information parameter about the maximum length of connection needed for this LE connection. Time = N * 0.625 msec. * @retval Value indicating success or error code. */ tBleStatus aci_gap_start_connection_update(uint16_t Connection_Handle, uint16_t Conn_Interval_Min, uint16_t Conn_Interval_Max, uint16_t Conn_Latency, uint16_t Supervision_Timeout, uint16_t Minimum_CE_Length, uint16_t Maximum_CE_Length); /** * @brief Send the SM pairing request to start a pairing process. The authentication requirements and IO capabilities should be set before issuing this command using the @ref aci_gap_set_io_capability and @ref aci_gap_set_authentication_requirement commands. A @ref aci_gap_pairing_complete_event event is returned after the pairing process is completed. * @param Connection_Handle Connection handle for which the command is given. * Values: - 0x0000 ... 0x0EFF * @param Force_Rebond If 1, Pairing request will be sent even if the device was previously bonded, otherwise pairing request is not sent. * Values: - 0x00: NO - 0x01: YES * @retval Value indicating success or error code. */ tBleStatus aci_gap_send_pairing_req(uint16_t Connection_Handle, uint8_t Force_Rebond); /** * @brief This command tries to resolve the address provided with the IRKs present in its database. If the address is resolved successfully with any one of the IRKs present in the database, it returns success and also the corresponding public/static random address stored with the IRK in the database. * @param Address Address to be resolved * @param[out] Actual_Address The public or static random address of the peer device, distributed during pairing phase. * @retval Value indicating success or error code. */ tBleStatus aci_gap_resolve_private_addr(uint8_t Address[6], uint8_t Actual_Address[6]); /** * @brief This command puts the device into broadcast mode. A privacy enabled device uses either a resolvable private address or a non-resolvable private address as specified in the Own_Addr_Type parameter of the command. * @param Advertising_Interval_Min Minimum advertising interval. Time = N * 0.625 msec. * Values: - 0x0020 (20.000 ms) ... 0x4000 (10240.000 ms) * @param Advertising_Interval_Max Maximum advertising interval. Time = N * 0.625 msec. * Values: - 0x0020 (20.000 ms) ... 0x4000 (10240.000 ms) * @param Advertising_Type Non connectable advertising type * Values: - 0x02: ADV_SCAN_IND (Scannable undirected advertising) - 0x03: ADV_NONCONN_IND (Non connectable undirected advertising) * @param Own_Address_Type If Privacy is disabled, then the address can be public or static random. If Privacy is enabled, then the address can be a resolvable private address or a non-resolvable private address. * Values: - 0x00: Public address - 0x01: Static random address - 0x02: Resolvable private address - 0x03: Non-resolvable private address * @param Adv_Data_Length Length of the advertising data in the advertising packet. * @param Adv_Data Advertising data used by the device while advertising. * @param Num_of_Whitelist_Entries Number of devices that have to be added to the whitelist. * @param Whitelist_Entry See @ref Whitelist_Entry_t * @retval Value indicating success or error code. */ tBleStatus aci_gap_set_broadcast_mode(uint16_t Advertising_Interval_Min, uint16_t Advertising_Interval_Max, uint8_t Advertising_Type, uint8_t Own_Address_Type, uint8_t Adv_Data_Length, uint8_t Adv_Data[], uint8_t Num_of_Whitelist_Entries, Whitelist_Entry_t Whitelist_Entry[]); /** * @brief Starts an Observation procedure, when the device is in Observer Role. The host enables scanning in the controller. The advertising reports are sent to the upper layer using standard LE Advertising Report Event. (See Bluetooth Core v4.1, Vol. 2, part E, Ch. 7.7.65.2, LE Advertising Report Event). If controller privacy is enabled and the peer device (advertiser) is in the resolving list then the link layer will generate a RPA, if it is not then the RPA/NRPA generated by the Host will be used. * @param LE_Scan_Interval This is defined as the time interval from when the Controller started its last LE scan until it begins the subsequent LE scan. Time = N * 0.625 msec. * Values: - 0x0004 (2.500 ms) ... 0x4000 (10240.000 ms) * @param LE_Scan_Window Amount of time for the duration of the LE scan. LE_Scan_Window shall be less than or equal to LE_Scan_Interval. Time = N * 0.625 msec. * Values: - 0x0004 (2.500 ms) ... 0x4000 (10240.000 ms) * @param LE_Scan_Type Passive or active scanning. With active scanning SCAN_REQ packets are sent. * Values: - 0x00: Passive Scanning - 0x01: Active scanning * @param Own_Address_Type Own address type: - 0x00: Public Device Address (it is allowed only if privacy is disabled) - 0x01: Random Device Address (it is allowed only if privacy is disabled) - 0x02: Resolvable Private Address (it is allowed only if privacy is enabled) - 0x03: Non Resolvable Private Address (it is allowed only if privacy is enabled) * Values: - 0x00: Public Device Address - 0x01: Random Device Address - 0x02: Resolvable Private Address - 0x03: Non Resolvable Private Address * @param Filter_Duplicates Enable/disable duplicate filtering. * Values: - 0x00: Duplicate filtering disabled - 0x01: Duplicate filtering enabled * @param Scanning_Filter_Policy Scanning filter policy: - 0x00 Accept all advertisement packets (it is allowed only if controller privacy is enabled).Directed advertising packets which are not addressed for this device shall be ignored. - 0x01 Ignore advertisement packets from devices not in the White List Only.Directed advertising packets which are not addressed for this device shall be ignored. - 0x02 Accept all undirected advertisement packets (it is allowed only if controller privacy or host privacy is enabled).Directed advertisement packets where initiator address is a RPA and Directed advertisement packets addressed to this device shall be accepted. - 0x03 Accept all undirected advertisement packets from devices that are in the White List.Directed advertisement packets where initiator address is RPA and Directed advertisement packets addressed to this device shall be accepted. - NOTE: If Host privacy is enabled Scanning_Filter_Policy can only take values 0x00 or 0x01; * Values: - 0x00: Accept all - 0x01: Ignore devices not in the White List - 0x02: Accept all (use resolving list) - 0x03: Ignore devices not in the White List (use resolving list) * @retval Value indicating success or error code. */ tBleStatus aci_gap_start_observation_proc(uint16_t LE_Scan_Interval, uint16_t LE_Scan_Window, uint8_t LE_Scan_Type, uint8_t Own_Address_Type, uint8_t Filter_Duplicates, uint8_t Scanning_Filter_Policy); /** * @brief This command gets the list of the devices which are bonded. It returns the number of addresses and the corresponding address types and values. * @param[out] Num_of_Addresses The number of bonded devices * @param[out] Bonded_Device_Entry See @ref Bonded_Device_Entry_t * @retval Value indicating success or error code. */ tBleStatus aci_gap_get_bonded_devices(uint8_t *Num_of_Addresses, Bonded_Device_Entry_t Bonded_Device_Entry[]); /** * @brief The command finds whether the device, whose address is specified in the command, is bonded. If the device is using a resolvable private address and it has been bonded, then the command will return BLE_STATUS_SUCCESS. * @param Peer_Address_Type Address type. * Values: - 0x00: Public Device Address - 0x01: Random Device Address * @param Peer_Address Address used by the peer device while advertising * @retval Value indicating success or error code. */ tBleStatus aci_gap_is_device_bonded(uint8_t Peer_Address_Type, uint8_t Peer_Address[6]); /** * @brief This command allows the User to validate/confirm or not the Numeric Comparison value showed through the ACI_GAP_Numeric_Comparison_Value_Event. * @param Connection_Handle Connection handle for which the command is given. * Values: - 0x0000 ... 0x0EFF * @param Confirm_Yes_No 0 : The Numeric Values showed on both local and peer device are different! 1 : The Numeric Values showed on both local and peer device are equal! * Values: - 0x00: No - 0x01: YES * @retval Value indicating success or error code. */ tBleStatus aci_gap_numeric_comparison_value_confirm_yesno(uint16_t Connection_Handle, uint8_t Confirm_Yes_No); /** * @brief This command permits to signal to the Stack the input type detected during Passkey input. * @param Connection_Handle Connection handle for which the command is given. * Values: - 0x0000 ... 0x0EFF * @param Input_Type Passkey input type detected * Values: - 0x00: Passkey entry started - 0x01: Passkey digit entered - 0x02: Passkey digit erased - 0x03: Passkey cleared - 0x04: Passkey entry completed * @retval Value indicating success or error code. */ tBleStatus aci_gap_passkey_input(uint16_t Connection_Handle, uint8_t Input_Type); /** * @brief This command is sent by the User to get (i.e. to extract from the Stack) the OOB data generated by the Stack itself. In a complete system (i.e. having an OOB channel fully handled) this command should be invoked by the OOB Channel manager to require the local OOB data (hence without user interaction) to be sent via OOB to the remote peer candidate device. The requested OOB data are returned in response to the incoming command. The OOB data are not generated on the fly, but they are already available in the Stack. * @param OOB_Data_Type OOB Data type * Values: - 0x00: Legacy Privacy (LP) v.4.1 TK (Temporary Key) - 0x01: Secure Connections (SC) v.4.2 Random value r used for generation of Confirm - 0x02: Secure Connections (SC) v.4.2 Confirm value C generated through AES-CMAC-128 based cryptographic function: C=f4(PKx, PKx, r, 0) * @param[out] Address_Type Identity address type. * Values: - 0x00: Public Identity Address - 0x01: Random (static) Identity Address * @param[out] Address Public or Random (static) address of this device * @param[out] OOB_Data_Len Length of OOB Data carried by next data field * @param[out] OOB_Data OOB Data to be exported via OOB. * @retval Value indicating success or error code. */ tBleStatus aci_gap_get_oob_data(uint8_t OOB_Data_Type, uint8_t *Address_Type, uint8_t Address[6], uint8_t *OOB_Data_Len, uint8_t OOB_Data[16]); /** * @brief This command is sent (by the User) to input the OOB data arrived via OOB communication. It may be sent to set either the OOB Authentication data of the Local device, or the data received via OOB by the Remote peer candidate device. It can be used with OOB_Data_Len set to 0 to generate OOB authentication data for Secure Connections. In a complete system (i.e. having an OOB channel fully handled) this command should be invoked by the OOB Channel manager when receiving the OOB data (hence without user interaction). Since the BLE stack v 2.x implementation supports just one entry for the Remote peer candidate list containing the OOB data, at every command invocation the data existing in that entry are overwritten. * @param Device_Type OOB Device type: - 0x00: The Address information are ignored. - OOB_Data_Len= 0x00: this triggers the automatic regeneration of OOB Authentication data (for Secure Connections only; a ECDH-Public Key must). - OOB_Data_Len in [0..16]: the OOB_Data carried by the command will overwrite the current local Authentication OOB Data. - 0x01: The Address information is used to search the entry of the Remote peer candidate list containing the OOB data for that specific remote device; if no entry exists, the a new entry is used, if available (current implementation supports just 1 entry in this list). - OOB_Data_Len in [0..16]: the OOB_Data carried by the command overwrites (if present) the remote Authentication OOB Data. * Values: - 0x00: Local device - 0x01: Remote device * @param Address_Type Identity address type. * Values: - 0x00: Public Identity Address - 0x01: Random (static) Identity Address * @param Address Public or Random (static) address of the peer device * @param OOB_Data_Type OOB Data type * Values: - 0x00: Legacy Privacy (LP) v.4.1 TK (Temporary Key) - 0x01: Secure Connections (SC) v.4.2 Random value r used for generation of Confirm - 0x02: Secure Connections (SC) v.4.2 Confirm value C generated through AES-CMAC-128 based cryptographic function: C=f4(PKx, PKx, r, 0) * @param OOB_Data_Len Length of OOB Data carried by next data field * @param OOB_Data OOB Data to be exported via OOB. * @retval Value indicating success or error code. */ tBleStatus aci_gap_set_oob_data(uint8_t Device_Type, uint8_t Address_Type, uint8_t Address[6], uint8_t OOB_Data_Type, uint8_t OOB_Data_Len, uint8_t OOB_Data[16]); /** * @brief This command is used to add one device to the list of address translations used to resolve Resolvable Private Addresses in the Controller. * @param Num_of_Resolving_list_Entries Number of devices that have to be added to the resolving list. * @param Whitelist_Identity_Entry See @ref Whitelist_Identity_Entry_t * @param Clear_Resolving_List Clear the resolving list * @retval Value indicating success or error code. */ tBleStatus aci_gap_add_devices_to_resolving_list(uint8_t Num_of_Resolving_list_Entries, Whitelist_Identity_Entry_t Whitelist_Identity_Entry[], uint8_t Clear_Resolving_List); /** * @brief This command can be used to remove a specified device from the bonding table. * @param Peer_Identity_Address_Type Identity address type. * Values: - 0x00: Public Identity Address - 0x01: Random (static) Identity Address * @param Peer_Identity_Address Public or Random (static) Identity address of the peer device * @retval Value indicating success or error code. */ tBleStatus aci_gap_remove_bonded_device(uint8_t Peer_Identity_Address_Type, uint8_t Peer_Identity_Address[6]); /** * @} */ #endif /* _BLUENRG1_GAP_ACI_H_ */