nRF5 SDK for Mesh v5.0.0
mesh_lpn.h
1 /* Copyright (c) 2010 - 2020, Nordic Semiconductor ASA
2  * All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without modification,
5  * are permitted provided that the following conditions are met:
6  *
7  * 1. Redistributions of source code must retain the above copyright notice, this
8  * list of conditions and the following disclaimer.
9  *
10  * 2. Redistributions in binary form, except as embedded into a Nordic
11  * Semiconductor ASA integrated circuit in a product or a software update for
12  * such product, must reproduce the above copyright notice, this list of
13  * conditions and the following disclaimer in the documentation and/or other
14  * materials provided with the distribution.
15  *
16  * 3. Neither the name of Nordic Semiconductor ASA nor the names of its
17  * contributors may be used to endorse or promote products derived from this
18  * software without specific prior written permission.
19  *
20  * 4. This software, with or without modification, must only be used with a
21  * Nordic Semiconductor ASA integrated circuit.
22  *
23  * 5. Any software provided in binary form under this license must not be reverse
24  * engineered, decompiled, modified and/or disassembled.
25  *
26  * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS
27  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
28  * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE
29  * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA OR CONTRIBUTORS BE
30  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
31  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
32  * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
33  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
34  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
35  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36  */
37 
38 #ifndef MESH_LPN_H__
39 #define MESH_LPN_H__
40 
41 #include <stdint.h>
42 #include "mesh_friendship_types.h"
43 #include "nrf_mesh_events.h"
44 
58 #define MESH_LPN_FRIEND_REQUEST_TIMEOUT_MIN_MS 100
59 
60 #define MESH_LPN_FRIEND_REQUEST_TIMEOUT_MAX_MS 1000
61 
63 #define MESH_LPN_POLL_TIMEOUT_MIN_MS 1000
64 
66 #define MESH_LPN_POLL_TIMEOUT_MAX_MS 345599900
67 
68 /* See @tagMeshSp section 3.6.5.3 Friend Request */
70 #define MESH_LPN_RECEIVE_DELAY_MIN_MS 10
71 
72 #define MESH_LPN_RECEIVE_DELAY_MAX_MS 255
73 
76 #ifndef MESH_LPN_POLL_RETRY_COUNT
77 #define MESH_LPN_POLL_RETRY_COUNT 5
78 #endif
79 
81 #ifndef MESH_LPN_FRIEND_REQUEST_RETRY_COUNT
82 #define MESH_LPN_FRIEND_REQUEST_RETRY_COUNT 5
83 #endif
84 
86 #ifndef MESH_LPN_POLL_SEPARATION_INTERVAL_MS
87 #define MESH_LPN_POLL_SEPARATION_INTERVAL_MS 50
88 #endif
89 
90 
92 typedef struct
93 {
96  uint8_t rssi_factor : 2;
99  uint8_t receive_window_factor : 2;
103 
105 typedef struct
106 {
120  uint32_t poll_timeout_ms;
133 
135 void mesh_lpn_init(void);
136 
164  uint32_t request_timeout_ms);
165 
189 uint32_t mesh_lpn_friend_accept(const nrf_mesh_evt_lpn_friend_offer_t * p_friend_offer);
190 
204 uint32_t mesh_lpn_friend_poll(uint32_t delay_ms);
205 
231 uint32_t mesh_lpn_poll_interval_set(uint32_t poll_interval_ms);
232 
245 uint32_t mesh_lpn_friendship_terminate(void);
246 
251 bool mesh_lpn_is_in_friendship(void);
252 
255 #endif /* MESH_LPN_H__ */
uint32_t mesh_lpn_friend_accept(const nrf_mesh_evt_lpn_friend_offer_t *p_friend_offer)
Accept a Friend Offer.
uint32_t receive_delay_ms
Requested receive delay (in milliseconds).
Definition: mesh_lpn.h:108
uint32_t mesh_lpn_poll_interval_set(uint32_t poll_interval_ms)
Set the poll interval.
uint8_t receive_window_factor
Weight factor that the Friend node will apply to the offered Receive Window.
Definition: mesh_lpn.h:99
bool mesh_lpn_is_in_friendship(void)
Get the state of the LPN.
uint32_t mesh_lpn_friend_request(mesh_lpn_friend_request_t friend_params, uint32_t request_timeout_ms)
Initiate the friendship establishment procedure.
void mesh_lpn_init(void)
Initialize the Low Power node.
uint8_t rssi_factor
Weight factor that the Friend node will apply to the received RSSI.
Definition: mesh_lpn.h:96
uint32_t poll_timeout_ms
Poll timeout (in milliseconds).
Definition: mesh_lpn.h:120
friend_criteria_t friend_criteria
Criteria that a Friend node must support to participate in the friendship negotiation.
Definition: mesh_lpn.h:131
Parameters of the Friend node Criteria field.
Definition: mesh_lpn.h:92
uint32_t mesh_lpn_friendship_terminate(void)
Terminate the active friendship.
Friend Request parameters.
Definition: mesh_lpn.h:105
uint8_t friend_queue_size_min_log
Minimum Friend Queue size.
Definition: mesh_lpn.h:101
uint32_t mesh_lpn_friend_poll(uint32_t delay_ms)
Initiate a Friend Poll.

Documentation feedback | Developer Zone | Subscribe | Updated