forked from justind000/nRF-IoT
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrelay.ino
106 lines (94 loc) · 3.34 KB
/
relay.ino
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
#include <SPI.h>
#include "nRF24L01.h"
#include "RF24.h"
RF24 radio(9,10);
#define BASEBROADCAST(x) (0xBB00000000LL + x)
#define RELAYBROADCAST(x) (0xAA00000000LL + x)
#define NODEACK(x) (0xCC00000000LL + x)
struct SENSOR{
float temp;
float humidity;
float pressure;
};
struct HEADER{
long type;
long hops;
long src;
long ID;
SENSOR sensor;
};
HEADER header; //used throughout
long cnt[10] = {}; //array used to store the last 10 header.IDs
byte cntID = 0; //counter for header.ID array
bool DupID(long id){
//this function keeps the last 10 header.IDs, then searches through them all
//when cntID reaches 10, it rolls over to 0 again
//if a match is found, it returns true, falst otherwise
bool found = false;
for (int i = 0; i < 10; i++)
if (cnt [i] == id){
found = true;
break;}
if (cntID < 10){cnt[cntID] = id;}
else{cntID = 0;cnt[cntID] = id;}
cntID++;
return found;
}
void setup(void){
Serial.begin(57600);
randomSeed(analogRead(0)); //here just for the testing bit on the bottom
//setup radio
radio.begin();
radio.setRetries( 15,15 );
radio.enableDynamicPayloads();
radio.openReadingPipe( 1, RELAYBROADCAST(2) ); //relays send on this
radio.openReadingPipe( 2, RELAYBROADCAST(1) ); //Nodes send on this
radio.startListening();
Serial.println("relay starting...");
}
void loop(void){
//check to see if we have anything available
if ( radio.available() ){
bool done = false;
while (!done){
//read whatever is available
done = radio.read( &header, radio.getDynamicPayloadSize() );
Serial.print( "Got message from 0x" ); Serial.print( header.src, HEX );Serial.print( " ID:" );Serial.print( header.ID, HEX ); Serial.print( " Hops: " );Serial.println(header.hops);
}
delay(20); //wait a bit for node to switch to receiver
radio.stopListening();
radio.openWritingPipe( NODEACK(1) );
radio.write( &header.ID, sizeof(header.ID), true ); //send out ack with the id of our received message
radio.startListening();
//this could be an original node broadcast or it could be another relay's tx.
//they both get forwarded, DupID is used to stay out of an infinite loops of relays sending relays sending relays...
//so far remembering the last ten has worked. this might not work on a larger scale. Needs more testing.
if (!DupID(header.ID)){
radio.stopListening();
//send this on to the base
radio.openWritingPipe( BASEBROADCAST(1) );
bool ok = radio.write( &header, sizeof(header), true );
//and broadcast this to the other relays incase this relay cant reach the base
header.hops++; //only count relay hops, not passing from relay to base
radio.openWritingPipe( RELAYBROADCAST(2) );
radio.write( &header, sizeof(header), true );
radio.startListening();
}
}
delay(100);
//testing
if ( Serial.available() )
{
radio.stopListening();
Serial.read();
header.type = 0;
header.hops = 0;
header.src = 0xffff;
header.ID = random(1, 0xffff);
Serial.print(".");
//send a relay broadcast
radio.openWritingPipe(RELAYBROADCAST(2));
bool ok = radio.write( &header, sizeof(header), true );
radio.startListening();
}
}