BLE GAPM API. More...
Go to the source code of this file.
Classes | |
struct | gap_adv_param_t |
Advertising parameters for legacy advertising. More... | |
struct | gap_adv_prim_cfg_t |
Configuration for advertising on primary channel. More... | |
struct | gap_adv_second_cfg_t |
Configuration for advertising on secondary channel. More... | |
struct | gap_adv_period_cfg_t |
Configuration for periodic advertising. More... | |
struct | gap_ext_adv_param_t |
Advertising parameters for extended advertising and periodic advertising. More... | |
struct | gap_adv_time_param_t |
Advertising timing parameter. More... | |
struct | gap_sec_key_t |
Security key. More... | |
struct | gap_scan_param_t |
Parameters for legacy scanning. More... | |
struct | gap_scan_wd_op_param_t |
Scan Window operation parameters. More... | |
struct | gap_ext_scan_param_t |
Parameters for extended scanning. More... | |
struct | gap_period_adv_addr_cfg_t |
Periodic advertising information. More... | |
struct | gap_per_sync_param_t |
Periodic advertising synchronization parameters. More... | |
struct | gap_init_param_t |
Legacy initiating parameters. More... | |
struct | gap_ext_conn_param_t |
Connection parameters. More... | |
struct | gap_ext_init_param_t |
Extended initiating parameters. More... | |
struct | gap_lepsm_register_t |
LE Protocol/Service Multiplexer information. More... | |
struct | bond_dev_list_t |
Bonded device list. More... | |
struct | white_list_t |
White list. More... | |
struct | period_adv_list_t |
Periodic advertising list. More... | |
struct | gap_ral_dev_info_t |
RPA list item info. More... | |
struct | ral_dev_list_t |
RPA list info. More... | |
Macros | |
#define | CO_BIT(pos) (1UL<<(pos)) |
Bit operation helper. More... | |
#define | MAX_ADV_NUM 5 |
Maximal advertising instance number. More... | |
#define | MAX_PER_SYNC_NUM 5 |
Maximal periodic syncronization instance number. More... | |
#define | MAX_BOND_NUM 10 |
Maximal bonding number. More... | |
#define | MAX_WL_NUM 10 |
Maximal white list number. More... | |
#define | MAX_PRD_ADV_NUM 4 |
Maximal periodic advertising list number. More... | |
#define | MAX_KEY_LEN 16 |
The key length. More... | |
#define | INVALID_ADV_IDX 0xFF |
Invalid adv index. More... | |
#define | BLE_GAP_DEVNAME_DEFAULT "GOODIX_BLE" |
Default device name value. More... | |
#define | BLE_GAP_DEVNAME_MAX_LEN 248 |
Maximal length of device name. More... | |
#define | BLE_APPEARANCE_UNKNOWN 0 |
Unknown. More... | |
#define | BLE_APPEARANCE_GENERIC_PHONE 64 |
Generic Phone. More... | |
#define | BLE_APPEARANCE_GENERIC_COMPUTER 128 |
Generic Computer. More... | |
#define | BLE_APPEARANCE_GENERIC_WATCH 192 |
Generic Watch. More... | |
#define | BLE_APPEARANCE_WATCH_SPORTS_WATCH 193 |
Watch: Sports Watch. More... | |
#define | BLE_APPEARANCE_GENERIC_CLOCK 256 |
Generic Clock. More... | |
#define | BLE_APPEARANCE_GENERIC_DISPLAY 320 |
Generic Display. More... | |
#define | BLE_APPEARANCE_GENERIC_REMOTE_CONTROL 384 |
Generic Remote Control. More... | |
#define | BLE_APPEARANCE_GENERIC_EYE_GLASSES 448 |
Generic Eye-glasses. More... | |
#define | BLE_APPEARANCE_GENERIC_TAG 512 |
Generic Tag. More... | |
#define | BLE_APPEARANCE_GENERIC_KEYRING 576 |
Generic Keyring. More... | |
#define | BLE_APPEARANCE_GENERIC_MEDIA_PLAYER 640 |
Generic Media Player. More... | |
#define | BLE_APPEARANCE_GENERIC_BARCODE_SCANNER 704 |
Generic Barcode Scanner. More... | |
#define | BLE_APPEARANCE_GENERIC_THERMOMETER 768 |
Generic Thermometer. More... | |
#define | BLE_APPEARANCE_THERMOMETER_EAR 769 |
Thermometer: Ear. More... | |
#define | BLE_APPEARANCE_GENERIC_HEART_RATE_SENSOR 832 |
Generic Heart Rate Sensor. More... | |
#define | BLE_APPEARANCE_HEART_RATE_SENSOR_HEART_RATE_BELT 833 |
Heart Rate Sensor: Heart Rate Belt. More... | |
#define | BLE_APPEARANCE_GENERIC_BLOOD_PRESSURE 896 |
Generic Blood Pressure. More... | |
#define | BLE_APPEARANCE_BLOOD_PRESSURE_ARM 897 |
Blood Pressure: Arm. More... | |
#define | BLE_APPEARANCE_BLOOD_PRESSURE_WRIST 898 |
Blood Pressure: Wrist. More... | |
#define | BLE_APPEARANCE_GENERIC_HID 960 |
Human Interface Device (HID). More... | |
#define | BLE_APPEARANCE_HID_KEYBOARD 961 |
Keyboard (HID Subtype). More... | |
#define | BLE_APPEARANCE_HID_MOUSE 962 |
Mouse (HID Subtype). More... | |
#define | BLE_APPEARANCE_HID_JOYSTICK 963 |
Joystick (HID Subtype). More... | |
#define | BLE_APPEARANCE_HID_GAMEPAD 964 |
Gamepad (HID Subtype). More... | |
#define | BLE_APPEARANCE_HID_DIGITIZERSUBTYPE 965 |
Digitizer Tablet (HID Subtype). More... | |
#define | BLE_APPEARANCE_HID_CARD_READER 966 |
Card Reader (HID Subtype). More... | |
#define | BLE_APPEARANCE_HID_DIGITAL_PEN 967 |
Digital Pen (HID Subtype). More... | |
#define | BLE_APPEARANCE_HID_BARCODE 968 |
Barcode Scanner (HID Subtype). More... | |
#define | BLE_APPEARANCE_GENERIC_GLUCOSE_METER 1024 |
Generic Glucose Meter. More... | |
#define | BLE_APPEARANCE_GENERIC_RUNNING_WALKING_SENSOR 1088 |
Generic Running Walking Sensor. More... | |
#define | BLE_APPEARANCE_RUNNING_WALKING_SENSOR_IN_SHOE 1089 |
Running Walking Sensor: In-Shoe. More... | |
#define | BLE_APPEARANCE_RUNNING_WALKING_SENSOR_ON_SHOE 1090 |
Running Walking Sensor: On-Shoe. More... | |
#define | BLE_APPEARANCE_RUNNING_WALKING_SENSOR_ON_HIP 1091 |
Running Walking Sensor: On-Hip. More... | |
#define | BLE_APPEARANCE_GENERIC_CYCLING 1152 |
Generic Cycling. More... | |
#define | BLE_APPEARANCE_CYCLING_CYCLING_COMPUTER 1153 |
Cycling: Cycling Computer. More... | |
#define | BLE_APPEARANCE_CYCLING_SPEED_SENSOR 1154 |
Cycling: Speed Sensor. More... | |
#define | BLE_APPEARANCE_CYCLING_CADENCE_SENSOR 1155 |
Cycling: Cadence Sensor. More... | |
#define | BLE_APPEARANCE_CYCLING_POWER_SENSOR 1156 |
Cycling: Power Sensor. More... | |
#define | BLE_APPEARANCE_CYCLING_SPEED_CADENCE_SENSOR 1157 |
Cycling: Speed and Cadence Sensor. More... | |
#define | BLE_APPEARANCE_GENERIC_PULSE_OXIMETER 3136 |
Generic Pulse Oximeter. More... | |
#define | BLE_APPEARANCE_PULSE_OXIMETER_FINGERTIP 3137 |
Fingertip (Pulse Oximeter subtype). More... | |
#define | BLE_APPEARANCE_PULSE_OXIMETER_WRIST_WORN 3138 |
Wrist Worn(Pulse Oximeter subtype). More... | |
#define | BLE_APPEARANCE_GENERIC_WEIGHT_SCALE 3200 |
Generic Weight Scale. More... | |
#define | BLE_APPEARANCE_GENERIC_OUTDOOR_SPORTS_ACT 5184 |
Generic Outdoor Sports Activity. More... | |
#define | BLE_APPEARANCE_OUTDOOR_SPORTS_ACT_LOC_DISP 5185 |
Location Display Device (Outdoor Sports Activity subtype). More... | |
#define | BLE_APPEARANCE_OUTDOOR_SPORTS_ACT_LOC_AND_NAV_DISP 5186 |
Location and Navigation Display Device (Outdoor Sports Activity subtype). More... | |
#define | BLE_APPEARANCE_OUTDOOR_SPORTS_ACT_LOC_POD 5187 |
Location Pod (Outdoor Sports Activity subtype). More... | |
#define | BLE_APPEARANCE_OUTDOOR_SPORTS_ACT_LOC_AND_NAV_POD 5188 |
Location and Navigation Pod (Outdoor Sports Activity subtype). More... | |
#define | BLE_GAP_PHY_ANY 0x00 |
No preferred PHY. More... | |
#define | BLE_GAP_PHY_LE_1MBPS (1 << 0) |
LE 1M PHY preferred for an active link. More... | |
#define | BLE_GAP_PHY_LE_2MBPS (1 << 1) |
LE 2M PHY preferred for an active link. More... | |
#define | BLE_GAP_PHY_LE_CODED (1 << 2) |
LE Coded PHY preferred for an active link. More... | |
#define | GAP_ADV_CHANNEL_37 0x01 |
Advertising Channel 37 (2402MHz). More... | |
#define | GAP_ADV_CHANNEL_38 0x02 |
Advertising Channel 38 (2426MHz). More... | |
#define | GAP_ADV_CHANNEL_39 0x04 |
Advertising Channel 39 (2480MHz). More... | |
#define | GAP_ADV_CHANNEL_37_38_39 0x07 |
Advertising Channel 37, 38, 39. More... | |
Functions | |
void | ble_gap_pair_enable (bool enable) |
Decide whether to support the pair feature. More... | |
uint16_t | ble_gap_addr_set (gap_bdaddr_t const *p_addr) |
Set the device identity address (public or random static). More... | |
uint16_t | ble_gap_addr_get (gap_bdaddr_t *p_addr) |
Get the device identity address (public or random static). More... | |
uint16_t | ble_gap_tx_power_set (gap_activity_role_t role, uint8_t index, int8_t txpwr_dbm) |
Set the tx power. More... | |
uint16_t | ble_gap_tx_power_get (gap_activity_role_t role, uint8_t index, int8_t *txpwr_dbm) |
Get the tx power. More... | |
uint16_t | ble_gap_default_tx_power_set (int8_t txpwr_dbm) |
Set the default tx power for all roles. More... | |
uint16_t | ble_gap_default_tx_power_get (int8_t *txpwr_dbm) |
Get the default tx power for all roles. More... | |
uint16_t | ble_gap_irk_set (gap_sec_key_t *p_irk) |
Set IRK used for resolvable random BD address generation (LSB first). More... | |
uint16_t | ble_gap_privacy_params_set (uint16_t renew_dur, bool enable_flag) |
Set privacy related parameters. More... | |
uint16_t | ble_gap_data_length_set (uint16_t sugg_max_tx_octet, uint16_t sugg_max_tx_time) |
Set suggested default LE data length. More... | |
uint16_t | ble_gap_l2cap_params_set (uint16_t max_mtu, uint16_t max_mps, uint8_t max_nb_lecb) |
Set L2CAP related parameters. More... | |
void | ble_gap_pref_phy_set (uint8_t tx_pref_phy, uint8_t rx_pref_phy) |
Set the preferred values for the transmitter PHY and receiver PHY. More... | |
uint16_t | ble_gap_path_compensation_set (int16_t tx_path_comp, int16_t rx_path_comp) |
Set the RF path gain or loss between the RF transceiver and the antenna contributed by intermediate components. More... | |
uint16_t | ble_gap_chnl_map_set (gap_chnl_map_t *p_chnl_map) |
Set advertising channel map before advertising starts. More... | |
uint16_t | ble_gap_bond_devs_get (bond_dev_list_t *p_bond_list) |
Get all bonded devices. More... | |
uint16_t | ble_gap_bond_dev_addr_get (uint8_t conn_idx, gap_bdaddr_t *p_peer_addr) |
Get BD address of the bonded device. More... | |
uint16_t | ble_gap_bond_devs_clear (void) |
Clear all bonded devices. More... | |
uint16_t | ble_gap_bond_dev_del (const gap_bdaddr_t *p_peer_addr) |
Delete a bond device with the specified BD address. More... | |
uint16_t | ble_gap_whitelist_get (white_list_t *p_whitelist) |
Get the content of the whole white list. More... | |
uint16_t | ble_gap_whitelist_add (const white_list_t *p_whitelist) |
Add the devices into current white list. More... | |
uint16_t | ble_gap_whitelist_del (const white_list_t *p_whitelist) |
Delete the devices out of current white list. More... | |
uint16_t | ble_gap_whitelist_clear (void) |
Clear all the entries in the current white list. More... | |
uint16_t | ble_gap_per_adv_list_get (period_adv_list_t *p_pal_list) |
Get the content of the whole periodic advertising list. More... | |
uint16_t | ble_gap_per_adv_list_add (const period_adv_list_t *p_pal_list) |
Add the devices into current periodic advertising list. More... | |
uint16_t | ble_gap_per_adv_list_del (const period_adv_list_t *p_pal_list) |
Delete the devices out of periodic advertising list. More... | |
uint16_t | ble_gap_per_adv_list_clear (void) |
Clear all the entries in the current periodic advertising list. More... | |
uint16_t | ble_gap_rpa_list_get (ral_dev_list_t *p_rpa_list) |
Get the RPA list info. More... | |
uint16_t | ble_gap_dev_info_get (gap_dev_info_get_type_t type) |
Get the device information according to param type. More... | |
uint16_t | ble_gap_adv_param_set (uint8_t adv_idx, gap_own_addr_t own_addr_type, gap_adv_param_t *p_adv_param) |
Set parameters for advertising. More... | |
uint16_t | ble_gap_ext_adv_param_set (uint8_t adv_idx, gap_own_addr_t own_addr_type, gap_ext_adv_param_t *p_adv_param) |
Set extended parameters for advertising. More... | |
uint16_t | ble_gap_adv_data_set (uint8_t adv_idx, gap_adv_data_type_t type, const uint8_t *p_data, uint16_t length) |
Set Advertising Data, Scan Response Data and Periodic Advertising Data. More... | |
uint16_t | ble_gap_update_adv_data (uint8_t adv_idx, gap_adv_data_type_t type, const uint8_t *p_data, uint16_t length) |
Update Advertising Data, Scan Response Data and Periodic Advertising Data. More... | |
uint16_t | ble_gap_adv_start (uint8_t adv_idx, gap_adv_time_param_t *p_timeout) |
Start advertising. More... | |
uint16_t | ble_gap_adv_stop (uint8_t adv_idx) |
Stop advertising. More... | |
uint16_t | ble_gap_scan_param_set (gap_own_addr_t own_addr_type, gap_scan_param_t *p_scan_param) |
Set parameters for scanning. More... | |
uint16_t | ble_gap_ext_scan_param_set (gap_own_addr_t own_addr_type, gap_ext_scan_param_t *p_scan_param) |
Set extended parameters for scanning. More... | |
uint16_t | ble_gap_scan_start (void) |
Start scanning. More... | |
uint16_t | ble_gap_scan_stop (void) |
Stop scanning. More... | |
uint16_t | ble_gap_per_sync_param_set (uint8_t per_sync_idx, gap_per_sync_param_t *p_per_sync_param) |
Set the parameters used for periodic sync. More... | |
uint16_t | ble_gap_per_sync_start (uint8_t per_sync_idx) |
Start to synchronize with periodic advertising from an advertiser and begin receiving periodic advertising packets. More... | |
uint16_t | ble_gap_per_sync_stop (uint8_t per_sync_idx) |
Stop periodic synchronization. More... | |
uint16_t | ble_gap_connect (gap_own_addr_t own_addr_type, gap_init_param_t *p_init_param) |
Start a legacy connection to a device. More... | |
uint16_t | ble_gap_ext_connect (gap_own_addr_t own_addr_type, gap_ext_init_param_t *p_init_param) |
Start an extended connection to a device. More... | |
uint16_t | ble_gap_connect_cancel (void) |
Cancel an initiated connection. More... | |
void | ble_gap_appearance_set (uint16_t appearance) |
Set GAP appearance value. More... | |
uint16_t | ble_gap_appearance_get (uint16_t *p_appearance) |
Get GAP appearance value. More... | |
void | ble_gap_ppcp_present_set (bool present_flag) |
Set GAP Peripheral Preferred Connection Parameters present flag. More... | |
uint16_t | ble_gap_ppcp_set (gap_conn_param_t const *p_conn_params) |
Set GAP Peripheral Preferred Connection Parameters. More... | |
uint16_t | ble_gap_ppcp_get (gap_conn_param_t *p_conn_params) |
Get GAP Peripheral Preferred Connection Parameters. More... | |
uint16_t | ble_gap_device_name_set (gap_dev_name_write_perm_t write_perm, uint8_t const *p_dev_name, uint16_t length) |
Set GAP device name. More... | |
uint16_t | ble_gap_device_name_get (uint8_t *p_dev_name, uint16_t *p_length) |
Get GAP device name. More... | |
uint16_t | ble_gap_lepsm_register (gap_lepsm_register_t *p_lepsm) |
Register a LE Protocol/Service Multiplexer. More... | |
uint16_t | ble_gap_lepsm_unregister (uint16_t le_psm) |
Unregister a LE Protocol/Service Multiplexer. More... | |
uint16_t | ble_gap_privacy_mode_set (gap_bdaddr_t peer_addr, privacy_mode_t mode) |
Set privacy mode for peer device. More... | |
uint16_t | ble_gap_rslv_addr_read (gap_rslv_addr_read_op_id_t op_code, gap_bdaddr_t peer_iden_addr) |
Read peer or local resolvable address. More... | |
BLE GAPM API.
All rights reserved.
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. Neither the name of GOODIX nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL COPYRIGHT HOLDERS AND CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Definition in file ble_gapm.h.