Bluetooth: Mesh: Add support for suspend/resume
In some cases the Friendship & Low Power Node features aren't available or feasible, however power saving is nevertheless required. This patch introduces two new APIs to suspend and resume the Mesh network. Currently, what this impacts is the LE scanning, the ability to allocate new outgoing buffers, as well as the model publishing, beacon and heartbeat timers. Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
This commit is contained in:
parent
3e11177a06
commit
e5b8f60bb6
6 changed files with 114 additions and 0 deletions
|
@ -279,6 +279,27 @@ int bt_mesh_init(const struct bt_mesh_prov *prov,
|
|||
*/
|
||||
void bt_mesh_reset(void);
|
||||
|
||||
/** @brief Suspend the Mesh network temporarily.
|
||||
*
|
||||
* This API can be used for power saving purposes, but the user should be
|
||||
* aware that leaving the local node suspended for a long period of time
|
||||
* may cause it to become permanently disconnected from the Mesh network.
|
||||
* If at all possible, the Friendship feature should be used instead, to
|
||||
* make the node into a Low Power Node.
|
||||
*
|
||||
* @return 0 on success, or (negative) error code on failure.
|
||||
*/
|
||||
int bt_mesh_suspend(void);
|
||||
|
||||
/** @brief Resume a suspended Mesh network.
|
||||
*
|
||||
* This API resumes the local node, after it has been suspended using the
|
||||
* bt_mesh_suspend() API.
|
||||
*
|
||||
* @return 0 on success, or (negative) error code on failure.
|
||||
*/
|
||||
int bt_mesh_resume(void);
|
||||
|
||||
/** @brief Provision the local Mesh Node.
|
||||
*
|
||||
* This API should normally not be used directly by the application. The
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue