Operating in power save modes
The nRF70 Series device supports multiple power save modes, enabling the device to minimize power consumption by shutting down most of the digital logic and RF circuits.
nRF70 Series device states
The power save state of the nRF70 Series device is described through a combination of the physical Power state of the logic or circuits and the logical Functional state as observed by the access point (AP).
Power state
The nRF70 Series device can be in one of the following power states:
Active: The device is ON constantly so that it can receive and transmit the data.
Sleep: The device is OFF to majority of the blocks that cannot receive and transmit the data. In this state, the device consumes low power (~15 µA). Real-time Clock (RTC) domain, RF retention memory, and firmware retention memory are powered ON to retain the state information.
Shutdown: The device is completely powered OFF. In this state, the device consumes very low power (~2 µA) and does not retain any state information (apart from the values in the OTP memory). The device will only respond to a BUCKEN assertion to wake from the Shutdown state.
Functional state
The state information of the device at the access point database can be either Active or Power Save. The device is in the Active state after the connection to a network.
The state change information must be given to an access point by a successful frame exchange. The nRF70 Series device can operate in either of the following two functional states:
Active: The device is in the Active state permanently. If the data exists, the access point can schedule transmission of the data to the device immediately.
Power Save (PS): The device is in the Sleep state most of the time, but can also be woken up to transmit and receive data. In this state, the access point buffers the required frames intended for the device. The device can make a transition between the Active and Sleep states according to the IEEE 802.11 power save protocol.
Power Save mode
The nRF70 Series device can operate in Active mode or Power Save mode. When the device changes from Active mode to Power Save mode, it informs the access point through a successful frame exchange.
Once the frame exchange completes, the access point buffers all the frames (multicast and broadcast) that are addressed to the device. The device wakes up to receive buffered traffic for every Delivery Traffic Indication Message (DTIM) beacon and goes back to the Sleep state for the remaining period.
The following Power Save modes are supported and can be configured by the user or application:
Permanent Active: The device is in the Active mode. The power consumption is high, but the performance is best in this mode.
Static Power Save: The device is in the Power Save mode. This mode saves the most power but provides the lowest throughput. This mode is not supported in the current release.
Dynamic Power Save: The device switches between Active and Power Save mode depending on the activity. It enters the Power Save mode due to inactivity (timer expiry) and returns to the Active mode due to application traffic. nRF70 Series devices operate in this mode by default. The user or application can change the device to the Permanent Active mode using the
NET_REQUEST_WIFI_PS
network management API.
Further the Wi-Fi® interface can be configured in one of the following dynamic Power Save modes:
Normal Power Save: Delivery Traffic Indication Message (DTIM). DTIM is the default configuration and enabled by the application based on the traffic profile.
Extended Power Save: Listen interval-based power save mode. The Listen interval based-Power Save mode is supported to enable devices to sleep longer than the DTIM period.
Deep sleep: Target Wake Time (TWT) power save. TWT can be enabled if the connected access point is Wi-Fi 6 capable.
Delivery Traffic Indication Message (DTIM)
Devices in DTIM Power Save mode can wake at any time to transmit uplink traffic, but can only receive downlink traffic (broadcast, multicast or unicast) immediately after receiving a DTIM beacon. To make the device in Power Save mode aware that the access point has buffered downlink traffic, the access point uses the Traffic Indication Map (TIM) element present in the beacon frames. The device in Power Save mode wakes up to receive the DTIM beacon and checks the status of the TIM element. This element indicates whether there are any buffered group frames or unicast frames that need to be retrieved from the access point.
Group frames
Group addressed frames are directed to all connected devices. When there is at least one device in PS mode in the Basic Service Set (BSS), the access point buffers the broadcast and multicast traffic and transmits at specific time to ensure that all associated devices can receive it.
The buffered group traffic is delivered immediately after a DTIM beacon. The following figure illustrates the group frame data retrieval mechanism in DTIM Power Save mode:
Unicast frames
Unicast frames are directed to an intended device. When a device in the PS mode parses a TIM element indicating any individually addressed buffered frames, retrieving the buffered frames depends on the IEEE power save operation modes.
Legacy Power Save mode
The Legacy PS mode mechanism is based on the PS-Poll frame retrieving the buffered frames from the AP. The PS-Poll frame is a short Control Frame containing the Association Identifier (AID) value of the device. In the Legacy PS mode, when the device receives a beacon with its AID in the TIM element, it initiates the frame delivery by transmitting a PS-POLL control frame to the AP. The AP acknowledges the PS-Poll frame and responds with a single buffered frame.
The device stays active and retrieves the buffered frame.
The AP also indicates that there are buffered frames for the device using the More Data subfield.
The device continues to retrieve buffered frames using PS-Poll frames until there are no more frames and the More Data subfield is set to 0
.
The device goes back into the Sleep state after retrieving all the buffered frames.
The following figure illustrates the unicast frame data retrieval mechanism in Legacy Power Save mode:
Wireless Multimedia (WMM) Power Save mode
The Wireless Multimedia Power Save mode uses the Automatic Power Save Delivery (APSD) mechanism to retrieve the individual unicast-buffered traffic. A device in the PS mode starts the Service Period (SP) by sending a trigger frame that is a QoS Data/QoS Null frame.
When the device receives a beacon with its AID in the TIM element, it initiates the SP by transmitting the trigger frame to the AP.
The AP sends one or more individually addressed buffered frames to the device.
The device remains active until the AP ends the SP by setting the End Of Service Period (EOSP) bit to 1
in the QoS Control field of the last QoS Data frame sent to the device.
The following figure illustrates the unicast frame data retrieval mechanism in WMM Power Save mode:
Legacy Power Save mode is the default option in nRF70 Series devices.
The user or application can configure the WMM mode using the NET_REQUEST_WIFI_PS
network management API.
The WMM mode does not deliver a significant performance or power difference when compared to Legacy mode in Dynamic Power Save operation.
The average power consumption of the device is affected by the DTIM period. The typical value is three beacons, for example, 307 ms for a beacon period of 100-time units. The higher DTIM period results in increased power saving and higher latency to the application data.
Extended Power Save
This feature helps legacy connections to go to extended power save similar to the Target Wake Time (TWT) feature in Wi-Fi 6. The device wakeup interval is adjusted to nearest multiple of the DTIM period. For example, when the Listen interval is 10, the device wakes up for every 9th beacon if the DTIM is 3, and wkaes up to the 8th beacon if the DTIM is 4. The device wakes up for the configured Listen interval instead of the DTIM beacon. It will miss the chance of receiving broadcast and multicast frames which get scheduled after the DTIM beacon.
Note
The Listen interval-based power needs to be enabled only if the application can handle loss broadcast frames.
Chances of losing broadcast frames increases with higher listen intervals.
The following parameters control the functionality of the extended power save operation.
Listen interval
The Listen interval is a field that is present in an association request frame.
It indicates how frequently the device will wake up to check for any buffered traffic by checking TIM IE in the beacon.
A larger value enables the devices to save more power by sleeping for longer periods.
Larger listen intervals add burden to the AP, as the AP will need to buffer frames much longer to the device and this may force the AP to decline connection.
Also if the buffered frames exceed the MPDU/MSDU lifetime then, they will be silently discarded by the AP which causes frame loss.
The typical listen interval is 10 beacons.
The Listen interval can be set using NET_REQUEST_WIFI_PS
API and should be called before connecting to the AP.
Wakeup mode
The device can be configured to wake up for the DTIM or Listen interval by using NET_REQUEST_WIFI_PS
API.
The device can switch from the DTIM to the Listen interval-based Power Save at runtime seamlessly.
The following figure illustrates the change in wakeup mode from the DTIM to the Listen interval.
The following figure illustrates the change in wakeup mode from the Listen interval to DTIM.
Target Wake Time (TWT)
Target Wake Time is a new feature in Wi-Fi 6. It allows devices to wake up at the negotiated times to transmit and receive data. The access point and devices reach a TWT agreement that defines when a station is active and ready to receive and transmit data.
The TWT mechanism allows each device to negotiate its wake-up period with the AP to transmit and receive data packets. Stations will only receive and transmit during the TWT Service Period and remain in the sleep state for the rest of the time.
Note
The device follows the TWT wake schedule to save power and does not wake up for DTIM beacons. It is not able to receive broadcast or multicast frames which are scheduled after the DTIM beacon. Applications are expected to keep note of this and set up TWT sessions based on their traffic profile.
An access point has more control over the network in TWT mode and decides which device is going to transmit and when. The AP decides how many and which Resource Units (RU) are to be used (an RU is a contiguous set of subcarriers). TWT offers more efficient scheduling of transmissions.
Devices can remain in the sleep state even longer, if required. Before Wi-Fi 6, a device would sleep for a DTIM period, wake up, exchange data, and then return to the sleep state for another DTIM period, repeating continuously. With the introduction of TWT in Wi-Fi 6, a device can sleep for seconds, minutes, or even hours. Some devices can be configured to communicate once a day to perform a transmission and sleep for the rest of the day.
The figure below illustrates the initiation of two independent TWT sessions. The TWT session commences with a trigger frame from the AP at a time determined during the TWT establishment frame exchange (TWT1 and TWT2 for devices 1 and 2 respectively).
Modes of operation in TWT mode
When the device is in the TWT mode, the following are the two modes of operation:
Individual: The device can choose when to wake up and sleep. It can negotiate an agreement with the AP to wake up for receiving or transmitting the data.
Broadcast: The AP provides the schedule to all devices that support broadcast TWT. This mode is not supported in the current release.
Here is an example of a typical sequence of states in a TWT use case:
Scan the network.
Connect to an access point.
Complete the application-level handshake.
Set up a TWT session using the following Wi-Fi shell command:
wifi twt setup
Tear down the TWT session.
An application can tear down an ongoing TWT session and enter DTIM Power Save mode, if it is expecting group addressed frames, and set up a TWT session again as applicable.
Devices are not expected to schedule transmission outside the TWT Service Period. An application can tear down an ongoing TWT session and schedule, if there is a requirement for immediate transmission.
To tear down a TWT session, use the following Wi-Fi shell commands:
wifi twt teardown wifi twt teardown_all
Key parameters
Following are the two key parameters of Target Wake Time:
TWT Wake Duration
The amount of time that the TWT requesting device needs to be active to complete the frame exchanges during the TWT wake interval.
Valid range for duration is 1 ms to 256 ms. Lower value results in more power saving at the cost of potential loss of data. It is recommended not to go lower than 8 ms. The application can choose a value lower than 8 ms at the cost of losing application data in the network.
The application must choose the right duration based on the traffic pattern.
Applications must take appropriate action if uplink or downlink traffic is more than anticipated. It could terminate the ongoing TWT session and negotiate a fresh session based on new requirements.
Downlink traffic:
Predictability is the key for choosing the correct wake duration.
Wake duration must be sufficient for the AP to schedule all the incoming traffic to devices. AP needs to contend the channel for scheduling frames and frames will be dropped if the duration is aggressive in busy channels.
AP will drop the device data if it cannot finish all transmission in the wake duration. AP may buffer traffic until the next interval if sleep duration is in the order of 100 ms. It will not buffer the device data if sleep duration is in the order of minutes and data will be lost.
Devices are allowed to sleep after the wake duration and there is no mechanism to extend the wake duration based on downlink traffic. Device must be active during the wake duration even if there is no downlink traffic.
Uplink traffic:
Trigger Enabled - When operating in Trigger Enabled mode, the nRF70 Series device:
schedules uplink traffic as a response to trigger frames from the AP.
expects the AP to schedule trigger frames in the wake duration.
discards all pending uplink frames after wake time expiry before entering the sleep state.
Non-trigger Enabled - When operating in Non-trigger Enabled mode, the nRF70 Series device:
schedules uplink traffic using the legacy channel contention.
tries to schedule all uplink traffic in the wake duration and discard pending frames.
discards all pending uplink frames after wake time expiry before entering the sleep state.
TWT Wake Interval
Interval between successive TWT wake periods.
Valid range for duration is one ms to a few days.
Application must choose the right interval based on the expected traffic.
The following figure illustrates the two key parameters of Target Wake Time:
Usage
DTIM-based power save is the default configuration of the device after connection to an access point. The wake-up and sleep period of the device is aligned to DTIM period advertised in the AP beacon. The access point is in control of DTIM period and can be configured while setting up the network. Stations connected to the AP cannot set or request a change in this value.
A higher DTIM period provides higher power saving in devices, but it adds latency to the downlink traffic. The latency of the DTIM period is seen in the device for the initial downlink traffic. A device can wake up and schedule uplink traffic at any time and latency of a few milliseconds is observed.
When operating in DTIM Power Save mode, the nRF70 Series device:
wakes up to receive DTIM beacons and decode TIM.
receives all broadcast or multicast frames after DTIM beacon.
retrieves all unicast frames using either PS-POLL or Trigger frames.
maintains the Wi-Fi connection by responding to the keep alive packet exchange at any point of time.
TWT-based power save allows devices to sleep for longer intervals than the DTIM power save. It is suitable for devices that have predictable periodic uplink or downlink traffic and do not have low latency requirements. DTIM-based power save is more efficient for sleep intervals that are in the range of milliseconds to a few seconds. TWT will perform better if the sleep interval is in the 10s of seconds and above range. DTIM-based power save performs better in high throughput applications compared to TWT. As the device sleeps longer and does not wake up to receive DTIM beacons, it misses all multicast or broadcast frames. The TWT session is expected to be set up by the application after the network level negotiation, after which it is not expected to receive any multicast or broadcast frames.
Power Save API
The following shell commands and network management APIs are provided for power save operations:
Network management APIs |
Command |
Description |
Expected output |
---|---|---|---|
net_mgmt(NET_REQUEST_WIFI_PS) |
wifi ps on |
Turn on power save feature |
Power Save enabled |
net_mgmt(NET_REQUEST_WIFI_PS) |
wifi ps off |
Turn off power save feature |
Power Save disabled |
net_mgmt(NET_REQUEST_WIFI_PS) |
wifi ps_mode legacy |
Config mode as Legacy |
|
net_mgmt(NET_REQUEST_WIFI_PS) |
wifi ps_mode wmm |
Config mode as WMM |
|
net_mgmt(NET_REQUEST_WIFI_PS) |
wifi ps_timeout |
Config ps timeout duration (in ms) |
|
net_mgmt(NET_REQUEST_WIFI_PS) |
wifi ps_listen_interval |
Config ps_listen_interval |
|
net_mgmt(NET_REQUEST_WIFI_PS) |
wifi ps_wakeup_mode dtim |
Config ps wakeup mode as DTIM |
Wakeup mode set to DTIM |
net_mgmt(NET_REQUEST_WIFI_PS) |
wifi ps_wakeup_mode listen_interval |
Config ps wakeup mode as listen_interval |
Wakeup mode set to listem interval |
net_mgmt(NET_REQUEST_WIFI_TWT) |
wifi twt setup 0 0 1 1 0 1 1 1 65000 52400 |
Set up TWT:
TWT wake interval - 524000 µs
TWT wake duration - 65000 µs
|
TWT operation TWT setup with dg - 1, flow_id - 1 requested |
net_mgmt(NET_REQUEST_WIFI_TWT) |
wifi twt teardown 0 0 1 1 |
Tear down TWT session |
TWT operation TWT setup with dg - 1, flow_id - 1 requested |
net_mgmt(NET_REQUEST_WIFI_TWT) |
wifi twt teardown_all |
Tear down all sessions |
TWT operation TWT teardown all flows |
See the Wi-Fi: Shell sample for more information.
Power profiling
The Power Profiler Kit II of Nordic Semiconductor can be used to measure the power consumption of nRF70 Series devices in Low-power mode. To measure the power consumption of the nRF70 Series device, complete the following steps:
Remove the jumper on P23 (VBAT jumper).
Connect GND on the PPK2 kit to any GND on the DK. You can use the P21 pin 1 labeled as GND (-).
Connect the Vout on the PPK2 kit to the P23 pin 1 on the DK.
Configure PPK2 as a source meter with 3.6 volts.
The following image shows the Power Profiler Kit II example output for DTIM wakeup.
To reproduce the plots for DTIM period of 3, complete the following steps using the Wi-Fi: Shell sample:
Configure an AP with DTIM value of 3.
Connect to the AP using the following Wi-Fi shell commands:
wifi scan wifi connect <SSID>
Check the connection status using the following Wi-Fi shell command:
wifi status
The following image shows the Power Profiler Kit II output for DTIM period of 3.
To reproduce the plots for TWT interval of one minute, complete the following steps using the Wi-Fi: Shell sample:
Connect to a TWT supported Wi-Fi 6 AP using the following Wi-Fi shell commands:
wifi scan wifi connect <SSID>
Check the connection status using the following Wi-Fi shell command:
wifi status
Start a TWT session using the following Wi-Fi shell command:
wifi twt setup 0 0 1 1 0 1 1 1 8 60000
The following image shows the Power Profiler Kit II output for TWT interval of one minute.