Part D. Message Sequence Charts
vAtlanta r00
Examples of message sequence charts showing the interactions of the Host Controller Interface with the Link Layer.
1. Introduction
This section shows typical interactions between Host Controller interface (HCI) commands and events and the Link Layer (LL). It focuses on the message sequence charts (MSCs) for the procedures specified in “Bluetooth Host Controller Interface Functional Specification” with regard to Link Layer control procedures from “Link Layer”. This section illustrates only the most useful scenarios; it does not cover all possible alternatives. Furthermore, the message sequence charts do not consider errors over the air interface or Host interface. In all message sequence charts it is assumed that all events are not masked, so the Controller will not filter out any events.
The sequence of messages in these message sequence charts is for illustrative purposes. The messages may be sent in a different order where allowed by the Link Layer or HCI. If any of these charts differ with text in the Link Layer or HCI Parts, the text in those Parts overrides these charts.
1.1. Notation
The notation used in the message sequence charts (MSCs) consists of ovals, elongated hexagons, boxes, lines, and arrows. The vertical lines terminated on the top by a shadow box and at the bottom by solid oval indicate a protocol entity that resides in a device. MSCs describe interactions between these entities and states those entities may be in.
The following symbols represent interactions and states:
Oval | Defines the context for the message sequence chart |
Hexagon | Indicates a condition needed to start the transactions below this hexagon. The location and width of the Hexagon indicates which entity or entities make this decision. |
Box | Replaces a group of transactions. May indicate a user action, or a procedure in the Link Layer. |
Dashed Box | Optional group of transactions. |
Solid Arrow | Represents a message, signal or transaction. Can be used to show Link Layer and HCI traffic. |
Dashed Arrow | Represents an optional message, signal or transaction. Can be used to show Link Layer and HCI traffic. |
1.2. Control flow
Some message sequences are split into several charts. In these charts, numbers indicate normal or required ordering and letters represent alternative paths. For example, Step 4 is after Step 3, and Step 5a could be executed instead of Step 5b.
1.3. Example MSC
The protocol entities represented in the example shown in Figure 1.1 illustrate the interactions of two devices named A and B; each device includes a Host and a LL entity in this example. Other MSCs in this section may show the interactions of more than two devices.
data:image/s3,"s3://crabby-images/0a0e6/0a0e67eee306084efc291633913e60e8e301cb6e" alt="Example MSC"
1.4. Forward compatibility
Many of the message sequences in this Part use HCI commands or events that have enhanced or extended variants that were added to the specification later than the relevant sequence. Such variants can be related commands or events with different names (e.g,. HCI_LE_Advertising_Report and HCI_LE_Extended_Advertising_Report events) or commands or events with multiple versions (e.g., HCI_LE_Generate_DHKey command). In some instances (for example, see [Vol 4] Part E, Section 3.1.1), a Host is required to use the new variant rather than the one shown in the MSC. Even when this is not a requirement, Host implementers may prefer to use the newer variants.
In these circumstances, the MSCs have not been rewritten to use newer features but have been left unchanged. In general, the new commands and events will directly replace the old ones, but this is not always the case and readers should not assume it.
2. Standby state
2.1. Initial setup
To perform initial setup of a LE Controller, the following sequence of actions may be required.
First, the Host would wait for the Controller to indicate the number of HCI Command packets the Host is currently allowed to send using a Command Complete event on a No OPeration command opcode. Then it would reset the Controller to a known state. Then it needs to read the local supported features to check that low energy is supported on this Controller. It would then set the event mask and LE event mask to enable the events that it wants the Controller to generate to the Host. Next, it will check the buffers that are available for data flow, using the Read Buffer Size and LE Read Buffer Size commands. Then it would read the locally supported LE features and select the features that it wishes to use. Finally, it will read the public device address if the Controller has one (see Figure 2.1).
data:image/s3,"s3://crabby-images/124d5/124d5d0e4076ee38455bd48c8d73a3b8f7dd2ce3" alt="Initial setup"
2.2. Random Device address
A device may use a random device address, but this address has to be configured before being used during advertising, scanning or initiating (see Figure 2.2).
data:image/s3,"s3://crabby-images/42884/42884f2ac36a778cec42443e9d5aa3375bd99ef3" alt="Random device address"
2.3. Filter Accept List
Before advertising, scanning or initiating can use a Filter Accept List, the Filter Accept List may be cleared and devices added in as required (see Figure 2.3).
data:image/s3,"s3://crabby-images/b2ae3/b2ae3932de31f3f2feed3963b0536fd431db624c" alt="Filter Accept List"
2.4. Adding IRK to resolving list
Before advertising, scanning or initiating can use resolving lists, the resolving list may be cleared and devices added in as required (see Figure 2.4).
data:image/s3,"s3://crabby-images/76c66/76c662f09058c8025af466cfbea609024b7e0289" alt="Resolving lists"
2.5. Default data length
Before creating a connection, the Host may specify its preferred values for the Controller’s maximum transmission packet size and maximum packet transmission time to be used for new connections. This may be done on either the Central or the Peripheral.
data:image/s3,"s3://crabby-images/15f07/15f07d88c7f1db0894f772a1f43dc38efd8f454c" alt="Default data length"
2.6. Periodic Advertiser List
The Periodic Advertiser List may be cleared and entries added as required, before it is made use of (see Figure 2.6).
data:image/s3,"s3://crabby-images/99854/998545e1968f049ab5bac8ee73654bc4c47b4410" alt="Periodic Advertiser List"
3. Advertising state
3.1. Undirected advertising
A device may enter the Advertising state by enabling advertising. It should also configure the advertising parameters before doing this (see Figure 3.1).
data:image/s3,"s3://crabby-images/912bc/912bceeafd0e9009cf82e1ce737927f81759db98" alt="Undirected advertising"
3.2. Directed advertising
A device may use directed advertising to allow an initiator to connect to it. High duty cycle directed advertising is time limited in the Controller and therefore this may fail before a connection is created. This example only shows the failure case (see Figure 3.2).
data:image/s3,"s3://crabby-images/3c102/3c102231312c5ad1ce051e6e2b36a79f758d2d90" alt="High duty cycle directed advertising showing failure case"
Low duty cycle directed advertising is not time-limited. This example shows the case where no connection is made. A device should also configure the advertising parameters before doing this (see Figure 3.3).
data:image/s3,"s3://crabby-images/d839c/d839c3a2107935626c2e1e043b1b3bca520b41b0" alt="Low duty cycle directed advertising"
3.3. Advertising using ADV_EXT_IND
A device may enter the Advertising state by enabling advertising a set. It should also configure the advertising set parameters before doing this (see Figure 3.4).
data:image/s3,"s3://crabby-images/307bc/307bc161eb1662a9772d0f6ac29d75f42cfc0936" alt="Advertising using ADV_EXT_IND"
3.4. Scan request notifications
A device may enable scan request notifications in an advertising set (see Figure 3.5).
data:image/s3,"s3://crabby-images/bb68d/bb68df2f1f50370a4167d83d0344d386aca1414b" alt="Scan request notifications"
3.5. Advertising duration ended
A device may enter the Advertising State by enabling advertising a set for a limited duration of time (see Figure 3.6).
data:image/s3,"s3://crabby-images/3452b/3452b8f2ba58dd3b0152796e1fa879980f784f59" alt="Advertising duration ended"
3.6. Periodic advertising
A device may enter the Advertising State by enabling periodic advertising in a set. It should also configure the advertising set parameters before doing this (see Figure 3.7).
data:image/s3,"s3://crabby-images/1735a/1735a22f86baf7cffa3956ea73bba6d9e756ebb9" alt="Periodic advertising"
3.7. Connectionless Constant Tone Extension transmission
A device may send periodic advertising packets containing a Constant Tone Extension (see Figure 3.8).
data:image/s3,"s3://crabby-images/4fa6f/4fa6f4610f2b46f1d0b52a08f8af2d5214a91922" alt="Connectionless CTE transmission"
3.8. Isochronous Broadcasting State
3.8.1. Create a Broadcast Isochronous Group
A device enters the Isochronous Broadcasting State and enables the periodic advertising associated with the BIG. The device then creates the BIG and sends isochronous data using the isochronous data paths (see Figure 3.9).
data:image/s3,"s3://crabby-images/4278e/4278e137bb18ba7f4bfc70a9766560f41ceb9476" alt="Device A creates a BIG"
3.8.2. Terminate a Broadcast Isochronous Group
A device terminates a BIG (see Figure 3.10).
data:image/s3,"s3://crabby-images/3c726/3c726b6e3ab7d04e5ad013a7d41d37a21777ef90" alt="Device A terminates a BIG"
3.9. Periodic advertising with responses (PAwR)
A device may enter the Advertising state by enabling PAwR in a set. The device should configure the advertising set parameters before doing this (see Figure 3.11).
data:image/s3,"s3://crabby-images/4abb1/4abb1c1275f34244cb632f121868e008d396d8c7" alt="Configuring PAwR"
3.10. Transmitting PAwR subevents
A Controller may request data to be sent in one or more subevents of a PAwR advertising set. The Host can send this data to the Controller ahead of when the subevents are scheduled.
data:image/s3,"s3://crabby-images/b3b5b/b3b5bbb310a297cbb8e0f9d3b0937e86f859347e" alt="Transmitting PAwR subevents"
3.11. Using a response slot in PAwR
A device can send a response to a PAwR advertisement packet. The timing of the response is determined by the Host using information from the advertisement packet. The Host can send a response by indicating the response slot and data to be sent in that response slot.
data:image/s3,"s3://crabby-images/a2a77/a2a7792c1bf6d82b40f77e974e98b7aaac3a5877" alt="Using a response slot in PAwR"
3.12. Connecting from PAwR
A device may initiate a connection with a synchronized device by using the LE Extended Create Connection command which indicates the subevent and BD_ADDR of the peer device. This initiates a connection by sending an AUX_CONNECT_REQ PDU in that subevent.
data:image/s3,"s3://crabby-images/3a0e2/3a0e249d145c62f353e3f9033b6bf35ad7c114d8" alt="Connecting from PAwR"
3.13. Failed Connection Attempts From PAWR
A synchronized device can miss an AUX_CONNECT_REQ PDU sent by the periodic advertiser.
data:image/s3,"s3://crabby-images/a83a8/a83a8590de449fa2a90d6a5ff39327a45e9d4fdc" alt="Synchronized device misses the AUX_CONNECT_REQ PDU"
The periodic advertiser can miss an AUX_CONNECT_RSP PDU sent by a synchronized device.
data:image/s3,"s3://crabby-images/c4197/c4197be3fd03d629e263801a1e99942a4c9a0458" alt="Periodic advertiser misses the AUX_CONNECT_RSP PDU"
4. Scanning state
4.1. Passive scanning
A device can use passive scanning to find advertising devices in the area. This would receive advertising packets from peer devices and report these to the Host (see Figure 4.1).
data:image/s3,"s3://crabby-images/015ac/015ac5f96ae1d38d21b176fea7b00c43397e5039" alt="Passive scanning"
4.2. Active scanning
A device may use active scanning to obtain more information about devices that may be useful to populate a user interface. Active scanning involves more Link Layer advertising messages (see Figure 4.2).
data:image/s3,"s3://crabby-images/86375/863753fdd69e6eda5ef380793e0cfc7d4dd461fa" alt="Active scanning"
4.3. Passive scanning for directed advertisements with Privacy
If a device does not support Privacy in the Controller, it may choose to forward LE Directed Advertising Report events from devices supporting Privacy without requiring filtering through the Controller Resolving List.
data:image/s3,"s3://crabby-images/916b8/916b872ab070fdeb5545e5924ae6e907b18cab90" alt="Directed advertising with Privacy"
4.4. Active scanning with Privacy
A device may use active scanning to obtain more information about devices that may be useful to populate a user interface. Privacy may be used during active scanning to make it more difficult to track either device during active scanning (see Figure 4.4).
data:image/s3,"s3://crabby-images/cfc3d/cfc3d06bf28ab9cd5ff87f26c165dd31afc7f3ae" alt="Active scanning with Privacy"
4.5. Active scanning with Privacy and Controller based resolvable private address generation
A Controller will periodically update the resolvable private addresses used on both devices if the devices use active scanning and advertising with Privacy. A Host may at anytime retrieve the read from the Controller the current addresses being used (see Figure 4.5).
data:image/s3,"s3://crabby-images/d837a/d837a7e3f06c41dcbe90c778f16aae4bf3f4c9af" alt="Retrieving local and remote resolvable address updates from the Controller"
4.6. Active scanning on the secondary advertising Physical channel
A device may use active scanning on the secondary advertising physical channel in order to obtain more information about devices that may be useful to populate a user interface (see Figure 4.6).
data:image/s3,"s3://crabby-images/0682e/0682e47141aaa242999a1a01bb35dbd6fbf1a6c5" alt="Extended active scanning on the secondary advertising physical channel"
4.7. Scan timeout
A device may scan for a limited duration of time (see Figure 4.7).
data:image/s3,"s3://crabby-images/e040f/e040f9eab7b1f8e553651733c2d3b36ebeee11a5" alt="Scan timeout"
4.8. Scanning for periodic advertisements
A device may establish synchronization with a periodic advertiser and report periodic advertising packets to the Host (see Figure 4.8).
data:image/s3,"s3://crabby-images/f2570/f2570c699310889d7729a17aa029ab8ba841f366" alt="Periodic scanning"
4.9. Cancel scanning for periodic advertisements
A device may cancel a pending request to establish synchronization with a periodic advertiser. This example shows an unsuccessful synchronization, followed by cancellation of the synchronization (see Figure 4.9).
data:image/s3,"s3://crabby-images/e8a11/e8a11d7ec03be5b4ba9e638ee796919bae1c2703" alt="Periodic scanning cancel"
4.10. Periodic advertising synchronization timeout
A device may lose synchronization with a periodic advertiser (see Figure 4.10).
data:image/s3,"s3://crabby-images/40d75/40d75cbbe0b62cb83eadd0289f82fd74053219c7" alt="Periodic scanning timeout"
4.11. Terminate reception of periodic advertising
Once synchronized with a periodic advertiser, the Host can terminate the synchronization (see Figure 4.11).
data:image/s3,"s3://crabby-images/d7d59/d7d59acfd12155a166d414287b2fbce614ef8193" alt="Periodic scanning terminate"
4.12. Connectionless Constant Tone Extension reception
A device may receive periodic advertising packets containing a Constant Tone Extension and send IQ samples to the Host (see Figure 4.12).
data:image/s3,"s3://crabby-images/09aed/09aed7838d5ecc2e284163d8e0e89056716a78e9" alt="Connectionless Constant Tone Extension reception"
4.13. Synchronization with separate enable of reports
A device may enable or disable reports after establishing synchronization with a periodic advertising train.
data:image/s3,"s3://crabby-images/c352f/c352f94d7d83cb883e1c6c50d124abee47e1e49b" alt="Periodic scanning with separate enable"
5. Initiating state
5.1. Initiating a connection
A device can initiate a connection to an advertiser. This example shows a successful initiation, resulting in both devices able to send application data (see Figure 5.1).
data:image/s3,"s3://crabby-images/876e6/876e6487cf48c1d2387af759151f4de60101bc36" alt="Initiating a connection"
5.2. Canceling an initiation
A device can cancel a pending connection creation. This example shows an unsuccessful initiation, followed by a cancellation of the initiation (see Figure 5.2).
data:image/s3,"s3://crabby-images/572a5/572a5378484c0e31e17f03c5ded585cffcba9da4" alt="Canceling an initiation"
5.3. Initiating a connection using undirected advertising with Privacy
A device can initiate a connection to an advertiser. Privacy may be used during connection initiation to make it more difficult to track either device during connection setup. The example shows a successful initiation, resulting in both devices able to send application data (see Figure 5.3).
data:image/s3,"s3://crabby-images/b0b44/b0b44c4c1f2dcd06afd1f94e80eca1bf10aaf9d5" alt="Initiating a connection using undirected advertising with Privacy"
5.4. Initiating a connection using directed advertising with Privacy
A device can initiate a connection to an advertiser who is using Directed Advertising. Privacy may be used during connection initiation to make it more difficult to track either device during connection setup as well as target a single initiator. The example shows a successful initiation, resulting in both devices able to send application data (see Figure 5.4).
data:image/s3,"s3://crabby-images/905f6/905f68813df3abeec8df4636275d0c0631a99429" alt="Initiating a connection using directed advertising with Privacy"
5.5. Initiating a connection that fails to establish
This example shows an initiation that fails to establish because Device B (the advertiser) fails to respond to the Data Physical Channel PDUs sent by Device A.
data:image/s3,"s3://crabby-images/74d47/74d47bdd520e4b5c405f66960f9d792ff629d9da" alt="Initiating a connection that fails to establish"
Device A is not required to send Data Channel PDUs in the 6 connection intervals before establishment fails. However, if it does not do so, Device B is unable to respond.
5.6. Initiating a connection on the secondary advertising physical channel
A device can initiate a connection to an advertiser on the secondary channel. This example shows a successful initiation, resulting in both devices able to send application data (see Figure 5.6).
data:image/s3,"s3://crabby-images/63ecd/63ecdfec91cd0738a39a1d12ee11a3fc0a884be0" alt="Initiating a connection on the secondary advertising physical channel"
5.7. Initiating a Channel Selection algorithm #2 connection
Where a device supports the Channel Selection Algorithm #2 feature, it can initiate a connection which will use Channel Selection Algorithm #2 to an advertiser who has the ChSel field of the advertising physical channel PDU set to 1. The example shows a successful initiation, resulting in the connection using Channel Selection Algorithm #2.
data:image/s3,"s3://crabby-images/e2021/e202121e7163483e61928139af1a7e63b073e587" alt="Initiating a Channel Selection algorithm #2 connection"
6. Connection state
6.1. Sending data
Once two devices are in a connection, either device can send data. This example shows both devices sending data, for example when the Attribute Protocol does a read request and a read response is returned (see Figure 6.1).
data:image/s3,"s3://crabby-images/41da3/41da3181d6df16f37d443ffdfb210a755d8c40bf" alt="Sending data"
6.2. Connection update
The Central of the connection may request a connection update using a Link Layer control procedure (see Figure 6.2).
data:image/s3,"s3://crabby-images/d1e22/d1e22356a5004d927ed98ddfe3fd54ba400c3d47" alt="Connection update"
6.3. Channel map update
The Controller of the Central may receive some channel classification data from the Host and then perform the Channel Update Link Layer Control procedure (see Figure 6.3).
data:image/s3,"s3://crabby-images/4da04/4da04ebc8bfe42c41700d82a130a06e694784733" alt="Channel map update"
6.4. Features exchange
Both the Central and Peripheral can discover the set of features available on the remote device. To achieve this, the Feature Exchange Link Layer Control procedure is used (see Figure 6.4 and Figure 6.5).
data:image/s3,"s3://crabby-images/92ebb/92ebbae51867c456e220bff8e357ee000943f2d7" alt="Central-initiated features exchange"
data:image/s3,"s3://crabby-images/021e5/021e5c112f1ce4c1cb0404f8d73901d1a142129b" alt="Peripheral-initiated features exchange"
6.5. Version exchange
Either device may perform a Version Exchange procedure (see Figure 6.6 and Figure 6.7).
data:image/s3,"s3://crabby-images/8228e/8228e84fe1e12211ecb89bcfdca04efe7a98de4b" alt="Version exchange from Central"
data:image/s3,"s3://crabby-images/1c176/1c176ff8961d92c44c6ff4635f211e193a770584" alt="Version exchange from Peripheral"
6.6. Start encryption
If encryption has not been started on a connection, it may be started by the Central (see Figure 6.8).
data:image/s3,"s3://crabby-images/c5072/c5072a60dd67b66e9e0106b2196f4f62f1493d73" alt="Start encryption"
6.7. Start encryption without long-term key
If encryption has not been started on a connection, it may be started by the Central. Figure 6.9 shows the failure case of the Peripheral not having the long term key for the Central.
data:image/s3,"s3://crabby-images/cb778/cb778784100037b990871fb8bd38ec361aa115df" alt="Start encryption without long-term key"
6.8. Start encryption with event masked
If encryption has not been started on a connection, it may be started by the Central. Figure 6.10 shows the failure case when the Peripheral has masked out the HCI_LE_Long_Term_Key_Request event.
data:image/s3,"s3://crabby-images/d923c/d923cd7356533db54072e3dfd981c7faff502d1f" alt="Start encryption with Peripheral masking out event"
6.9. Start encryption without Peripheral supporting encryption
If encryption has not been started on a connection, it may be started by the Central. Figure 6.11 shows the failure case of the Peripheral that does not support the encryption feature.
data:image/s3,"s3://crabby-images/17410/17410272db6dc44f9fa416cc16c0726646806ea0" alt="Start encryption failure when Peripheral does not support encryption"
6.10. Restart encryption
If encryption has already been started on a connection, it may be restarted by the Central. This may be required to use a stronger encryption as negotiated by the Security Manager Protocol (see Figure 6.12).
data:image/s3,"s3://crabby-images/d19e5/d19e5aa40b90aba3d6f670e8fdfaec3b30865542" alt="Restart encryption"
6.11. Disconnect
Once a connection has no need to be kept active, the Host can disconnect it. This can be done by either device (see Figure 6.13 and Figure 6.14).
data:image/s3,"s3://crabby-images/2ad0d/2ad0d3a818cca3a490b1d419257d00c75331b2bd" alt="Disconnect from Central"
data:image/s3,"s3://crabby-images/76db9/76db99b2da48654557fdd3550feacbaf6244c39d" alt="Disconnect from Peripheral"
6.12. Connection parameters request
The Central or the Peripheral of the connection may request change in connection parameters using a Link Layer control procedure (see Figure 6.15 to Figure 6.22).
data:image/s3,"s3://crabby-images/2838a/2838a1da0b75cda83612236ee6f2a5a4adc8fdbe" alt="Peripheral-initiated Connection Parameters Request procedure - Peripheral requests a change in anchor points, Central accepts"
data:image/s3,"s3://crabby-images/c7087/c7087a54781ddb4f59962556903a8f547868c085" alt="Peripheral-initiated Connection Parameters Request procedure – Peripheral requests a change in anchor points, Central rejects"
data:image/s3,"s3://crabby-images/063f6/063f661838d019d096aff61643a6042b2e603b28" alt="Peripheral-initiated Connection Parameters Request procedure – Peripheral requests change in LE connection parameters, Central’s Host accepts"
data:image/s3,"s3://crabby-images/bd851/bd851568d410f357841acf6c1999211ff16e0527" alt="Peripheral-initiated Connection Parameters Request procedure – Peripheral requests change in LE connection parameters, Central’s Host rejects"
data:image/s3,"s3://crabby-images/a01f8/a01f8f55ffcb7c266a7972245a657fc97a9c61b7" alt="Central-initiated Connection Parameters Request procedure – Central requests a change in anchor points, Peripheral accepts"
data:image/s3,"s3://crabby-images/34122/34122a7fdf836d46688faf74fa99ee04552c99f1" alt="Central-initiated Connection Parameters Request procedure – Central requests a change in anchor points, Peripheral rejects"
data:image/s3,"s3://crabby-images/6cd13/6cd1307a8c2e57666e0051f2b4ee1d40c1f3213b" alt="Central-initiated Connection Parameters Request procedure – Central requests change in LE connection parameters, Peripheral’s Host accepts"
data:image/s3,"s3://crabby-images/add4b/add4b8b161d9a7fd3ffbbc70ceb7fb8ec65ed4b6" alt="Central-initiated Connection Parameters Request procedure – Central requests change in LE connection parameters, Peripheral’s Host rejects"
6.13. LE Ping
A Host may use the HCI_Write_Authenticated_Payload_Timeout command to change the maximum interval between packets containing a valid MIC that the Link Layer will enforce when encryption is used.
data:image/s3,"s3://crabby-images/aba52/aba5240bb0bb35c2c216b9ce88762873067924e7" alt="Set LE authenticated payload timeout"
Either Link Layer can authenticate the remote device using the LE Ping procedure even if the remote device does not support the LE Ping feature. This procedure can also be used for soliciting a packet from the remote device containing a valid MIC. LL A may be a Central or a Peripheral.
data:image/s3,"s3://crabby-images/b79c1/b79c13a738912d6d19bd7f5ab2fbd82686e6b82c" alt="Successful LE Ping"
When a packet with a valid MIC has not been received within the LE Authenticated Payload Timeout, the Host is notified that the timer has expired.
data:image/s3,"s3://crabby-images/4afc2/4afc26f3e1af2e5ee9af5645e446d42aa2b76e92" alt="Unsuccessful LE Ping"
The TLE_Authenticated_Payload Timer gets reset when the Host sets the Authenticated Payload Timeout.
data:image/s3,"s3://crabby-images/5a134/5a1346b976c8334c908dc4c516597a173472df8e" alt="TLE_Authenticated_Payload Timer reset"
6.14. Data length update
Once a connection has been created, the Host may suggest maximum transmission packet size and maximum packet transmission time to be used for the connection. This may be done on either the Central or the Peripheral.
data:image/s3,"s3://crabby-images/5497e/5497e77207fbf65e5a5dddd478a980abf2e38334" alt="Data length update"
6.15. PHY update
The Central or Peripheral of the connection may request a change in the PHY using a Link Layer control procedure (see Figure 6.28 to Figure 6.36).
The sequence of events shown in Figure 6.30 and Figure 6.33 can only happen before feature exchange and can only happen once per connection, because a Link Layer must not use a procedure that it knows the peer does not support as required by [Vol 6] Part B, Section 4.6.
data:image/s3,"s3://crabby-images/49863/4986366b5dfab5ae8de2df23e6a296ab58a789ee" alt="Central-initiated PHY Update procedure – Central requests a change of PHY, PHY changed in at least one direction"
data:image/s3,"s3://crabby-images/67b6c/67b6c95e631141ea44c78fda5023dfb22e6f651d" alt="Central-initiated PHY Update procedure – PHY not changed (either because Peripheral doesn't specify PHYs that the Central prefers, or because the Central concludes that the current PHYs are still best)"
data:image/s3,"s3://crabby-images/2ed3d/2ed3d30b4666a2b6601b50c1fbd46eb0bc2c9d6c" alt="Central-initiated PHY Update procedure – Central requests a change of PHY, Peripheral does not support the feature"
data:image/s3,"s3://crabby-images/bd7e2/bd7e29ab85fd652d96c61625c35a72a39b569750" alt="Peripheral-initiated PHY Update procedure – Peripheral requests a change of PHY, PHY changed in at least one direction"
data:image/s3,"s3://crabby-images/e4700/e4700a465055b15780538e2f7b951c07d0adb581" alt="Peripheral-initiated PHY Update procedure – PHY not changed (either because Peripheral doesn't specify PHYs that the Central prefers, or because the Central concludes that the current PHYs are still best)"
data:image/s3,"s3://crabby-images/4811f/4811f6f6a4e8f7340340426269ac62f6e1a290ee" alt="Peripheral-initiated PHY Update procedure – Peripheral requests a change of PHY, Central does not support the feature"
data:image/s3,"s3://crabby-images/d8fd8/d8fd89317d3a7c8cc3bbedca2455d95f18e2dd19" alt="Autonomous Central-initiated PHY Update procedure – Central requests a change of PHY, Peripheral accepts, PHY changed in at least one direction"
data:image/s3,"s3://crabby-images/f342f/f342fbe3355a9b224f06d4579447449840d66755" alt="Autonomous Central-initiated PHY Update procedure – Central requests a change of PHY, PHY not changed (either because Peripheral doesn't specify PHYs that the Central prefers, or because the Central concludes that the current PHYs are still best)"
data:image/s3,"s3://crabby-images/13378/133781d67a786c803ed901a2c51f15607eaaf70c" alt="Central and Peripheral crossover PHY Update procedure – Central and Peripheral request a change of PHY concurrently"
6.16. Minimum number of used channels request
Where a Peripheral supports the Minimum Number of Used Channels procedure, it can request that a certain minimum number of channels be used on the indicated PHY. The example shows a successful request, resulting in a channel map update with the requested minimum number of channels used for the connection.
data:image/s3,"s3://crabby-images/e428e/e428ee1a282fb796b1d691be459d841670faf882" alt="Requesting minimum number of used channels"
6.17. LL procedure collision
The Link Layers of both the Central and Peripheral may initiate the same LL procedure at the same time.
data:image/s3,"s3://crabby-images/5da4b/5da4b028d439efa55bb1547f99c5c8d77f1877de" alt="LL procedure collision"
6.18. Constant Tone Extension Request
The Central or Peripheral of the connection may request the remote device to send an LL_CTE_RSP PDU with a Constant Tone Extension (see Figure 6.39 to Figure 6.41).
The sequence of events shown in figure 6.40 can only happen before feature exchange and can only happen once per connection, because a Link Layer must not use a procedure that it knows the peer does not support as required by [Vol 6] Part B, Section 4.6.
data:image/s3,"s3://crabby-images/0450d/0450d5f40dcbee7ee1a7aa22738e4f6cba5c74ad" alt="Central or Peripheral-initiated Constant Tone Extension Request procedure – remote device responds successfully"
data:image/s3,"s3://crabby-images/06709/067098bc9c3864fbede719a53983cc928c561899" alt="Central or Peripheral-initiated Constant Tone Extension Request procedure – remote device does not support the feature"
data:image/s3,"s3://crabby-images/021b2/021b2085558b0aa8ee6035eb98dbed884d5ccfaa" alt="Central or Peripheral-initiated Constant Tone Extension Request procedure – remote device rejects"
6.19. Connected Isochronous Group Setup
A Central sets up a CIG with parameters for one or more CISes, then establishes a CIS with a Peripheral (see Figure 6.42).
data:image/s3,"s3://crabby-images/e6463/e64634071ddc809db734e2e68696777d05e6ba32" alt="Device A establishes a CIS with a Peripheral"
A Central sets up CIG parameters and establishes a CIS with two Peripherals (see Figure 6.43).
data:image/s3,"s3://crabby-images/1b347/1b347e06a5db923ec834ae23cf31765fa9dd0702" alt="Device A establishes CISes with two Peripherals"
6.20. Host Rejects Connected Isochronous Stream
The Peripheral’s Host rejects the request to establish a CIS with the Central (see Figure 6.44).
data:image/s3,"s3://crabby-images/9ef45/9ef45bcaa00eae48b3f2a0c6adb57eebb41601df" alt="The Host in Device B rejects a CIS from Device A"
While setting up CISes with two Peripherals, the Host of one of the Peripherals rejects the request to establish a CIS with the Central (see Figure 6.45).
data:image/s3,"s3://crabby-images/350e8/350e892a046b373621d46570f91fc67e75eb9959" alt="The Host in Device C rejects a CIS from Device A"
6.21. Link Layer Rejects Connected Isochronous Stream
The Link Layer of the Peripheral rejects the request to establish a CIS with a Central (see Figure 6.46).
data:image/s3,"s3://crabby-images/23958/239581f8172ada7aa3c49778ded6f13c4431a9d4" alt="The Link Layer in Device B rejects a CIS request from Device A"
While setting up CISes with two Peripherals, the Link Layer of one of the Peripherals rejects the request to establish a CIS with the Central (see Figure 6.47).
data:image/s3,"s3://crabby-images/b61ec/b61ec192f6187de4c38813fd331fc55de14ee3bf" alt="The Link Layer in Device C rejects a CIS from Device A"
6.22. Link Layer Rejects Connected Isochronous Stream
The Link Layer of the Central rejects the request to create a CIS (see Figure 6.48).
data:image/s3,"s3://crabby-images/e4554/e4554f6379c7a71b56a01a49f8d90fda39e8063f" alt="Link Layer in Device A rejects a request to create a CIS"
6.23. Host A Terminates Connected Isochronous Stream
The Host of the Central terminates a Connected Isochronous Stream (see Figure 6.49). Either A or B can be the Central.
data:image/s3,"s3://crabby-images/9face/9face1af27d4939a12fd0000bc0d16cf3fa69105" alt="Device A terminates an established CIS"
The Host of device A, which is the Central, terminates a Connected Isochronous Stream either before the Link Layer starts creating that CIS (see Figure 6.50) or during the creation process (see Figure 6.51).
data:image/s3,"s3://crabby-images/1b9c6/1b9c6ffe8bd5c4c59ef43f0f2261cd373c22e292" alt="Device A terminates a CIS before the Link Layer starts creating it"
data:image/s3,"s3://crabby-images/82833/82833706c3e06c66b396ff62df620a552785ac86" alt="Device A terminates a CIS during the creation process"
6.24. ACL disconnected
The disconnection of the ACL causes the disconnections of CISes (see Figure 6.52).
data:image/s3,"s3://crabby-images/1fdf5/1fdf5d3a063754bcbb7c7ea94e8848a32a6c7eb2" alt="ACL connection Terminated"
6.25. Host A Removes Connected Isochronous Group
A Host of the Central terminates the CIS and removes the CIG from the Link Layer (see Figure 6.53).
data:image/s3,"s3://crabby-images/485b1/485b134d491b6cf01585b0eecbfcb8ca67f6e085" alt="Device A terminates a CIS and removes a CIG"
The Host of the Central terminates both the CISes in the CIG and removes the CIG from the Controller (see Figure 6.54).
data:image/s3,"s3://crabby-images/78c89/78c898e3f74a834bcd3b09957dcb6e1c1fd4c4f9" alt="Device A terminates both CISes and removes the CIG"
6.26. Request Sleep Clock Accuracy
Either device can initiate a Sleep Clock Accuracy Update procedure to query the sleep clock accuracy of the peer device (see Figure 6.55).
data:image/s3,"s3://crabby-images/aea2e/aea2ee4f718ff0edb073d73be65b5600bc175a79" alt="Device A requests SCA from Device B"
6.27. Power Control
Either device can initiate a Power Control Request procedure to request the peer device to adjust its transmit power level (see Figure 6.56).
data:image/s3,"s3://crabby-images/5d7ed/5d7edba107e278e19eddada156f33a35d21fec51" alt="Power Control Request procedure to request remote transmit power update"
Either device can use the Power Control Request procedure to query the Acceptable Power Reduction (APR) value from the peer device and adjust its transmit power based on the response (see Figure 6.57).
data:image/s3,"s3://crabby-images/56999/5699919e2ec0c07ccb02333ea88d5b3ab6f3ae65" alt="Power Control Request procedure to query Acceptable Power Reduction (APR) and transmitter Update"
When the Host issues a command to enable reporting of remote power level changes, the Controller may initiate a Power Control Request procedure to request the remote device to start power level management (see [Vol 6] Part B, Section 4.5.15). When the remote Controller changes its transmit power level, it sends an indication to the peer device (see Figure 6.58). If reporting of remote transmit power level changes is enabled, the Controller sends an LE Transmit Power Reporting event to the Host.
data:image/s3,"s3://crabby-images/286a8/286a8490113bdbb47dd5eab95e7c77f938587bd8" alt="LL Power Change Indication procedure when device adjusts TX power autonomously"
When a Host issues a command to read the transmit power level of a remote device, the Controller can initiate an LL Power Control Request procedure to query the transmit power level of the remote device (see Figure 6.59).
data:image/s3,"s3://crabby-images/1b3d2/1b3d2de26459a29d92432fb1a8ae33f526eefd38" alt="HCI command to read remote transmit power level"
Before a PHY Update procedure is performed, the Link Layer may request a preferred transmit power level for the new PHY to be used by the remote device (see Figure 6.60).
data:image/s3,"s3://crabby-images/2b09b/2b09bc61e940963ed03e75e88f9c05b56eb619b6" alt="Autonomous Central-initiated PHY Update procedure with preferred transmit power level. PHY changed in both directions."
An implementation may choose to manage transmit power levels only on active PHYs and could reject a request for preferred transmit power level on the new PHY before a PHY Update procedure is performed (see Figure 6.61).
data:image/s3,"s3://crabby-images/0c61d/0c61dc3083eafb3cb85c12a3fb525219abc5d22b" alt="Autonomous Central-initiated PHY Update procedure with remote device maintaining only a single transmit power level. PHY changed in both directions."
When a PHY Update procedure is performed to switch to the LE Coded PHY, where the local and remote devices can use both S=8 and S=2 coding, the Controller treats them as separate PHYs for the purpose of Power Control (see Figure 6.62).
data:image/s3,"s3://crabby-images/086bc/086bc05308b63a6eb68f7d922de31eaaf3ec2e17" alt="Autonomous Central-initiated PHY Update procedure to change to the LE Coded PHY (S=8 and S=2). PHY changed in both directions."
When an associated CIS is established on a PHY different from the one used by ACL, the Power Change Indication procedure may be used to indicate the transmit power level used on the new PHY. When the associated CIS is disconnected, the implementations may choose to stop managing the PHY used on the CIS (see Figure 6.63).
data:image/s3,"s3://crabby-images/167a4/167a4a09e93796add93a2eba0c3838f7f9bc1f32" alt="ACL with associated CIS established on a new PHY different from one on ACL"
When a Host enables path loss monitoring, the Controller may initiate the Power Control Request procedure to query the remote transmit power level. As the remote device moves around, the Controller monitors the path loss on the connection and sends events to the Host as appropriate (see Figure 6.64).
data:image/s3,"s3://crabby-images/c0535/c0535f40e4296387acd8a04cd0e1ac224f420aef" alt="Power Control Request procedure in context of path loss monitoring"
6.28. Data path setup for a music stream over a CIS
Figure 6.65 shows an example of unidirectional music streaming from Host A to Host B. Host A does LC3 codec processing in the Host and sends data over HCI to the Controller, which transmits the PDUs over the air without further processing. Host B configures an output data path to the speaker(s) and enables LC3 codec processing in the Controller.
Note
Note: The notifications between the Hosts are specified by the relevant profile(s).
Note
Note: The audio data may be mono or stereo. In the latter case, how the data sent to the output data path is split into the separate audio signals is outside the scope of this specification.
data:image/s3,"s3://crabby-images/21339/21339977a25271aeed10eca1b54d9d4aa43f231e" alt="Host A with codec in the Host streams music to Host B which has a codec in the Controller"
6.29. Data path setup for bi-directional voice over a CIS
Figure 6.66 shows an example of a bidirectional voice call between Host A and Host B. Device A contains proprietary audio interface hardware with an embedded LC3 codec. Hence the Host sets up the ISO data path with Coding_Format set to transparent mode. Device B supports LC3 codec processing in the Controller and hence Host B sets up the ISO data path with Coding_Format set to LC3 along with the codec configuration data defined by the relevant profile(s).
Note
Note: The notifications between the Hosts are specified by the relevant profile(s).
data:image/s3,"s3://crabby-images/a5871/a58711f7397282b45d7224030bf258429723ed59" alt="Host A with codec in the data path establishes a bi-directional voice call with Host B with codec in the Controller"
6.30. [This section is no longer used]
The contents of this section are now in Section 8.5.
6.31. Modifying the subrate of a connection
A Central A in a connection with a Peripheral B modifies the subrating of the connection. The first two PDUs are not received by device B (see Figure 6.67).
data:image/s3,"s3://crabby-images/9bc63/9bc63abf2e977229c2c0da60d2a9f2bd3d048df4" alt="Central A modifies the connection subrating"
Peripheral B requests a new subrating for its connection with device A and makes the change (see Figure 6.68).
data:image/s3,"s3://crabby-images/9431a/9431a2f7486795634448b012d6af2df00c186d23" alt="Peripheral B requests a change to the connection subrate which is accepted"
Peripheral B requests a new Subrating for its connection with device A but device A rejects the change (see Figure 6.69).
data:image/s3,"s3://crabby-images/a5a2b/a5a2b86fc256c1716b2b04b840fa0369cd14309d" alt="Peripheral B requests a change to the connection subrate which is rejected"
6.32. Channel Classification Enable
The Central can enable reporting of channel classification information on the Peripheral.
data:image/s3,"s3://crabby-images/f312e/f312ef713d810d5a0ca4cfc46a99e4218940de66" alt="Central requests the Peripheral to enable reporting of channel classification information"
6.33. Channel Classification Reporting
The reporting is enabled, the Peripheral can provide channel classification information to the Central.
data:image/s3,"s3://crabby-images/29db5/29db59d740c5f5fcc26020b4de7862bb85d07062" alt="Peripheral provides channel classification information to the Central"
7. Periodic advertising sync transfer
In the following examples, device B is carrying out periodic advertising. Either device A or device B is in a connection with device C and transfers periodic advertising synchronization information about the periodic advertising train to device C.
7.1. Transfer by scanner, reports initially disabled
The scanning device (A) transfers periodic advertising synchronization information to device C, which starts listening to the periodic advertising train but only sends reports to the Host when explicitly requested.
![]() |
7.2. Transfer by scanner, reports initially enabled
The scanning device (A) transfers periodic advertising synchronization information to device C, which starts listening to the periodic advertising train and immediately sends reports to the Host.
data:image/s3,"s3://crabby-images/4523f/4523fc274196ae5bac08d2107f689cd1a2848f71" alt="Periodic Advertising Sync Transfer by scanner, reports initially enabled"
7.3. Transfer by the advertiser
The advertiser (B) directly transfers periodic advertising synchronization information about its periodic advertising to device C. In this example reports to Host C are disabled.
data:image/s3,"s3://crabby-images/fee55/fee55fcedeb61ac545d0d3db1b4f14fc10b7fdcc" alt="Periodic Advertising Sync Transfer by advertiser, reports initially disabled"
8. Synchronization state
8.1. Synchronizing with a Broadcast Isochronous Group
A device enters the Synchronization state, receives the synchronization information from the periodic advertising train that is associated with the BIG, and synchronizes to a BIS (see Figure 8.1).
data:image/s3,"s3://crabby-images/04929/049294fd8a200dab38163ca81052420dbcfdcb79" alt="Device B synchronizes with a BIG"
8.2. Terminate Synchronization with a BIG
A device terminates synchronization with a BIG (see Figure 8.2).
data:image/s3,"s3://crabby-images/92667/926672685bbefa0cd256ffba419cf3106ccd9b14" alt="Synchronization with a BIG is terminated"
8.3. New Channel Map for Broadcast Isochronous Group
A device receives a channel map update for a BIG (see Figure 8.3).
data:image/s3,"s3://crabby-images/46071/4607181413b35479998f7dafc7e72774f8573fea" alt="Device A sends a channel map update for a BIG"
8.4. Lost Synchronization with a Broadcast Isochronous Group
A device loses synchronization with a BIG (see Figure 8.4).
data:image/s3,"s3://crabby-images/975c5/975c5ee0d5543e06935f3ca300eb6e12c0401e12" alt="Device B loses synchronization with a BIG"
8.5. Data path setup for a BIS
Figure 8.5 shows an example of an isochronous broadcast stream from the Broadcaster A. Host A sets up the ISO data path with codec processing in the Controller to create the PDUs transmitted over the BIS. Device B becomes a Synchronized Receiver for the BIS and sets up the ISO data path to do codec processing in the Controller on the received data PDUs.
data:image/s3,"s3://crabby-images/ea698/ea698a44735d683f4e4352c87ac2b1bc518fcd89" alt="Isochronous broadcasting between devices which both have a codec in the Controller"