These fields can be omitted if all other FLAGS are 0 and the advertising packets is not connectable, allowing for 3 extra bytes for advertisement payload. Co-authored-by: Roudy Dagher <roudy.dagher@inria.fr>
1.6 KiB
NimBLE automated advertisements
Module for automated bluetooth advertising. Advertising is restarted on disconnect events automatically. Defaults to the following characteristics: - General discoverable mode (BLE_GAP_DISC_MODE_GEN) - Undirected connectable mode (BLE_GAP_CONN_MODE_UND) - No expiration (BLE_HS_FOREVER) - No name
It can be enabled by adding
USEMODULE += nimble_autoadv
to your makefile.
If your application is calling functions from nimble, e.g. ble_svc_gap_device_name_set(), NIMBLE_AUTOADV_START_MANUALLY should be set to 1 with the following line in your Makefile:
CFLAGS += -DNIMBLE_AUTOADV_START_MANUALLY=1
Then the application should call nimble_autoadv_adv_start() after all of its nimble calls to prevent errors like BLE_HS_EBUSY.
To specify a device name add the following line to your Makefile:
CFLAGS += -DNIMBLE_AUTOADV_DEVICE_NAME='"Riot OS device"'
By the default, in the advertised packet, the module includes the advertising Flags data type. According to Bluetooth Core Specification Supplement (see §1.3.1)
The Flags data type shall be included when any of the Flag bits are non-zero and the advertising packet is connectable, otherwise the Flags data type may be omitted.
If your application is not connectable (eg. a temperature sensor advertising
its current value), you might want omit this flag by clearing the
NIMBLE_AUTOADV_FLAG_FIELD
when including this module:
CFLAGS += -DNIMBLE_AUTOADV_FLAG_FIELD=0
This will grant three extra bytes in the advertisement packet.