commit | a94fc444257a39f0fc3b7d72c4a067b948437675 | [log] [tgz] |
---|---|---|
author | Abtin Keshavarzian <abtink@google.com> | Tue Mar 07 13:09:34 2023 -0800 |
committer | GitHub <noreply@github.com> | Tue Mar 07 13:09:34 2023 -0800 |
tree | edf87413a2425db0f7c2774be2f9ad16b9ac2fcd | |
parent | 130ef49cc409ee05c5dec35032280a45269a9080 [diff] |
[radio] mechanism to switch to PAN channel more quickly on CSL tx (#8701) This commit adds `mRxChannelAfterTxDone` in `otRadioFrame` which specifies the RX channel after frame TX is done (after all retries and ack received). This is intended for situations where they may be delay in interactions between OT stack and radio, as example this is used in RCP and host architecture to make sure RCP switches to PAN channel more quickly. In particular, this can help with CSL tx to a sleepy child, where the child may use a different channel for CSL than the PAN channel. After frame tx, we want the radio/RCP to go back to PAN channel quickly to ensure that parent does not miss any tx from child afterwards, e.g., child responding to the earlier CSL transmitted frame from parent using PAN channel while radio still staying on CSL channel. This commit adds support for the `mRxChannelAfterTxDone` parameter in spinel and posix host `RadioSpinel`. This is added in a backward compatible way, i.e., if RCP is using a newer version but host is older and does not provide the new parameter, RCP will use `frame.mChannel` as default value for this, and if host is using a newer version, older RCP will ignore it.
OpenThread released by Google is...
...an open-source implementation of the Thread networking protocol. Google Nest has released OpenThread to make the technology used in Nest products more broadly available to developers to accelerate the development of products for the connected home.
...OS and platform agnostic, with a narrow platform abstraction layer and a small memory footprint, making it highly portable. It supports both system-on-chip (SoC) and network co-processor (NCP) designs.
...a Thread Certified Component, implementing all features defined in the Thread 1.3.0 specification, including all Thread networking layers (IPv6, 6LoWPAN, IEEE 802.15.4 with MAC security, Mesh Link Establishment, Mesh Routing) and device roles, as well as Border Router support.
More information about Thread can be found at threadgroup.org. Thread is a registered trademark of the Thread Group, Inc.
All end-user documentation and guides are located at openthread.io. If you're looking to do things like...
...then openthread.io is the place for you.
Note: For users in China, end-user documentation is available at openthread.google.cn.
If you're interested in contributing to OpenThread, read on.
We would love for you to contribute to OpenThread and help make it even better than it is today! See our Contributing Guidelines for more information.
Contributors are required to abide by our Code of Conduct and Coding Conventions and Style Guide.
OpenThread is released under the BSD 3-Clause license. See the LICENSE
file for more information.
Please only use the OpenThread name and marks when accurately referencing this software distribution. Do not use the marks in a way that suggests you are endorsed by or otherwise affiliated with Nest, Google, or The Thread Group.
OpenThread support is available on GitHub: