Bluetooth low energy features

The Bluetooth low energy protocol stack in the SoftDevice has been designed to provide an abstract but flexible interface for application development for Bluetooth low energy devices.

GAP, GATT, SM, and L2CAP are implemented in the SoftDevice and managed through the API. The SoftDevice implements GAP and GATT procedures and modes that are common to most profiles such as the handling of discovery, connection, data transfer, and bonding.

The Bluetooth low energy API is consistent across Bluetooth role implementations where common features have the same interface. The following tables describe the features found in the Bluetooth low energy protocol stack.

Table 1. API features in the Bluetooth low energy stack
API features Description
Interface to GATT/GAP Consistency between APIs including shared data formats
Attribute table sizing, population, and access Full flexibility to size the attribute table at application compile time and to populate it at run time. Attribute removal is not supported.
Asynchronous and event driven Thread-safe function and event model enforced by the architecture
Vendor-specific (128-bit) UUIDs for proprietary profiles Compact, fast, and memory efficient management of 128-bit UUIDs
Packet flow control Full application control over data buffers to ensure maximum throughput
Application control of PHY Full application control over the PHYs negotiated in connections
Application control of MTU size and packet length Full application control of MTU size and packet length used in connections
Table 2. GAP features in the Bluetooth low energy stack
GAP features Description
Multirole Central, Peripheral, Observer, and Broadcaster can run concurrently with connections.
Multiple bond support Keys and peer information stored in application space.

No restrictions in stack implementation.

Security Mode 1, Levels 1, 2, 3, and 4 Support for all levels of SM 1
Table 3. GATT features in the Bluetooth low energy stack
GATT features Description
Full GATT Server Support for one ATT server per concurrent connection. Includes configurable Service Changed support.
Support for authorization Enables control points

Enables the application to provide fresh data

Enables GAP authorization

Full GATT Client Flexible data management options for packet transmission with either fine control or abstract management.
Implemented GATT Sub-procedures Exchange MTU

Discover all Primary Services

Discover Primary Service by Service UUID

Find included Services

Discover All Characteristics of a Service

Discover Characteristics by UUID

Discover All Characteristic Descriptors

Read Characteristic Value

Read using Characteristic UUID

Read Long Characteristic Values

Read Multiple Characteristic Values (Client only)

Write Without Response

Write Characteristic Value

Notifications

Indications

Read Characteristic Descriptors

Read Long Characteristic Descriptors

Write Characteristic Descriptors

Write Long Characteristic Values

Write Long Characteristic Descriptors

Reliable Writes

Table 4. SM features in the Bluetooth low energy stack
SM features Description
Flexible key generation and storage for reduced memory requirements Keys are stored directly in application memory to avoid unnecessary copies and memory constraints.
Authenticated MITM (man-in-the-middle) protection Allows for per-link elevation of the encryption security level.
Pairing methods:

Just works, Numeric Comparison, Passkey Entry, and Out of Band

API provides the application full control of the pairing sequences.
Table 5. ATT features in the Bluetooth low energy stack
ATT features Description
Server protocol Fast and memory efficient implementation of the ATT server role
Client protocol Fast and memory efficient implementation of the ATT client role
Configurable ATT_MTU size Allows for per-link configuration of ATT_MTU size
Table 6. L2CAP features in the Bluetooth low energy stack
L2CAP features Description
LE Credit-based Flow Control Mode Configurable support for up to 64 channels on each link
Table 7. LL features in the Bluetooth low energy stack
LL features Description
Master role

Scanner/Initiator roles

The SoftDevice supports multiple concurrent master connections and an additional Scanner/Initiator role. When the maximum number of simultaneous connections are established, the Scanner role will be supported for new device discovery. However, the Initiator is not available at that time.
Channel map configuration Setup of channel map for all master connections from the application.

Accepting update for the channel map for a slave connection.

Slave role

Advertiser/broadcaster role

The SoftDevice supports multiple concurrent peripheral connections and an additional Broadcaster or Advertiser. The Advertiser can only be started if the number of connections running is less than the maximum.
Master-initiated connection parameter update Central role may initiate connection parameter update. Peripheral role will accept connection parameter update.
LE Data Packet Length Extension (DLE) Up to 251 bytes of LL data channel packet payload. Both central and peripheral roles are able to initiate Data Length update procedure and respond to a peer-initiated Data Length update procedure.
LE 1M PHY

LE 2M PHY

LE connections transmitting and/or receiving packets on both LE 1M and LE 2M PHYs. Both symmetric (1M/1M, 2M/2M) and asymmetric (1M/2M, 2M/1M) connections are supported. Both central and peripheral roles are able to initiate a PHY update procedure and respond to a peer-initiated PHY update procedure.
Encryption  
RSSI

Channel-specific signal strength measurements during advertising, scanning, and central and peripheral connections.

LE Ping  
Privacy

The LL can generate and resolve resolvable private addresses in the advertiser, scanner, and initiator roles.

Extended Scanner Filter Policies  
Table 8. Proprietary features in the Bluetooth low energy stack
Proprietary features Description
TX Power control Access for the application to change transmit power settings for a specific role or connection handle.
Master Boot Record (MBR) for Device Firmware Update (DFU) Enables over-the-air firmware replacement, including full SoftDevice update capability.
Quality of Service (QoS) channel survey Measures the energy level of Bluetooth low energy channels. The application can then set an adapted channel map to avoid busy channels.
Channel map for Observer role Access for the application to set a channel map for the Observer role. This can be used to avoid busy or uninteresting channels.