-
Notifications
You must be signed in to change notification settings - Fork 153
/
RF24Mesh_config.h
142 lines (122 loc) · 5.09 KB
/
RF24Mesh_config.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
/**
* @file RF24Mesh_config.h
*
* macro definitions for configuring RF24Mesh
*/
#ifndef __RF24MESH_CONFIG_H__
#define __RF24MESH_CONFIG_H__
/*** User Configuration ***/
/**
* @brief Set 1 to 4 (Default: 4) Restricts the maximum children per node.
*
* The master node supports MESH_MAX_CHILDREN + 1 nodes
*/
#ifndef MESH_MAX_CHILDREN
#define MESH_MAX_CHILDREN 4
#endif // MESH_MAX_CHILDREN
#if defined(RF24_TINY)
#define MESH_NOMASTER
#endif
// un-comment for non-master nodes not running on ATTiny MCUs
//#define MESH_NOMASTER
/***Advanced User Config***/
/**
* @brief Radio channel to operate on 1-127.
*
* This is normally modified by calling RF24Mesh::setChannel()
*/
#ifndef MESH_DEFAULT_CHANNEL
#define MESH_DEFAULT_CHANNEL 97
#endif // MESH_DEFAULT_CHANNEL
/**
* @brief How long to attempt address renewal in milliseconds
* @see RF24Mesh::renewAddress()
*/
#ifndef MESH_RENEWAL_TIMEOUT
#define MESH_RENEWAL_TIMEOUT 7500
#endif // MESH_RENEWAL_TIMEOUT
/**
* @brief master node memory allocation
*
* On the master node memory for the address list (nodeIDs + RF24Network Addresses) is allocated dynamically and re-allocated using this value
*
* Example: With a value of 10, space for 10 nodes is allocated on startup. Adding an 11th node will re-allocate the memory space to support 10 more nodes.
*
* On 8-bit AVRs (Arduino Uno, Nano etc) each entry uses 3-bytes of memory space. Minimize this value to save memory. Allocate enough to prevent memory fragmentation.
*/
#ifndef MESH_MEM_ALLOC_SIZE
#define MESH_MEM_ALLOC_SIZE 10
#endif // MESH_MEM_ALLOC_SIZE
/**
* @brief Number of attempts to verify a connection
*
* On child nodes, when calling `mesh.checkConnection();`, configure how many attempts will be made to contact the master node to verify connectivity
* Raising this number can result in a more stable mesh, since nodes can more easily verify that a connection is active
*/
#ifndef MESH_CONNECTION_CHECK_ATTEMPTS
#define MESH_CONNECTION_CHECK_ATTEMPTS 3
#endif
#define RF24MESH_CONN_CHECK_PARENT 1
#define RF24MESH_CONN_CHECK_MASTER 0
/**
* @brief How to verify a connection
*
* On child nodes, determine how they verify/check their connection periodically, or when writes start to fail via the `RF24Mesh::checkConnection();`
* function.
* Set RF24MESH_CONN_CHECK_TYPE to @ref RF24MESH_CONN_CHECK_PARENT for the new behaviour of verifying connectivity only with their parent node.
* Set RF24MESH_CONN_CHECK_TYPE to @ref RF24MESH_CONN_CHECK_MASTER for the old behaviour of verifying connectivity with the master node.
* The old behaviour typically results in more network congestion, more load on the master node, and less reliable networks,
* but it can work well when radio conditions are good and/or when there are only a small number of nodes on the network and/or in close proximity
* to the master node.
*/
#ifndef RF24MESH_CONN_CHECK_TYPE
#define RF24MESH_CONN_CHECK_TYPE RF24MESH_CONN_CHECK_PARENT
// To use old behavior:
// #define RF24MESH_CONN_CHECK_TYPE RF24MESH_CONN_CHECK_MASTER
#endif
/**************************/
/*** Debug ***/
//#define RF24MESH_DEBUG_MINIMAL /** Uncomment for the Master Node to print out address assignments as they are assigned */
//#define RF24MESH_DEBUG /** Uncomment to enable debug output to serial **/
/**************************/
/*** Other Configuration ***/
//#define MESH_MIN_SAVE_TIME 30000 /** UNUSED Minimum time required before changing nodeID. Prevents excessive writing to EEPROM */
/**
* @brief How long to wait in ms for a response during individual address lookups
* @see RF24Mesh::getNodeID and RF24Mesh::getAddress
* If using distant nodes or a large number of nodes this value can be increased in general or for specific nodes.
* For Level 1 nodes a response typically takes 2-3ms in good conditions.
* For Level 2 nodes: 4-5ms, Level 3: 6-15ms, Level 4: 10-25ms
**/
#ifndef MESH_LOOKUP_TIMEOUT
#define MESH_LOOKUP_TIMEOUT 135
#endif // MESH_LOOKUP_TIMEOUT
/** @brief How long RF24Mesh::write() retries address lookups before timing out. Allows multiple attempts */
#ifndef MESH_WRITE_TIMEOUT
#define MESH_WRITE_TIMEOUT 115
#endif // MESH_WRITE_TIMEOUT
#ifndef MESH_DEFAULT_ADDRESS
#define MESH_DEFAULT_ADDRESS NETWORK_DEFAULT_ADDRESS
#endif // MESH_DEFAULT_ADDRESS
#define MESH_MULTICAST_ADDRESS NETWORK_MULTICAST_ADDRESS
//#define MESH_MAX_ADDRESSES 255 /* UNUSED Determines the max size of the array used for storing addresses on the Master Node */
//#define MESH_ADDRESS_HOLD_TIME 30000 /* UNUSED How long before a released address becomes available */
#if (defined(__linux) || defined(linux)) && !defined(__ARDUINO_X86__) && !defined(USE_RF24_LIB_SRC)
#include <RF24/RF24_config.h>
//ATXMega
#elif defined(XMEGA)
#include "../../rf24lib/rf24lib/RF24_config.h"
#else
#include <RF24_config.h>
#endif
#if defined(RF24MESH_DEBUG_MINIMAL)
#define IF_RF24MESH_DEBUG_MINIMAL(x) ({ x; })
#else
#define IF_RF24MESH_DEBUG_MINIMAL(x)
#endif
#if defined(RF24MESH_DEBUG)
#define IF_RF24MESH_DEBUG(x) ({ x; })
#else
#define IF_RF24MESH_DEBUG(x)
#endif
#endif // __RF24MESH_CONFIG_H__