RFM69_LowPowerLab/Examples/Node/Node.ino

150 lines
4.0 KiB
Arduino
Raw Normal View History

2013-06-20 22:06:39 +01:00
#include <RFM69.h>
#include <SPI.h>
2013-07-30 21:50:37 +01:00
#include <SPIFlash.h>
2013-06-20 22:06:39 +01:00
2013-07-30 21:50:37 +01:00
#define NODEID 99
2013-06-20 22:06:39 +01:00
#define NETWORKID 100
#define GATEWAYID 1
2013-07-30 21:50:37 +01:00
#define FREQUENCY RF69_915MHZ //Match this with the version of your Moteino! (others: RF69_433MHZ, RF69_868MHZ)
#define KEY "thisIsEncryptKey" //has to be same 16 characters/bytes on all nodes, not more not less!
2013-06-20 22:06:39 +01:00
#define LED 9
#define SERIAL_BAUD 115200
2013-07-30 21:50:37 +01:00
#define ACK_TIME 30 // # of ms to wait for an ack
2013-06-20 22:06:39 +01:00
2013-07-30 21:50:37 +01:00
int TRANSMITPERIOD = 300; //transmit a packet to gateway so often (in ms)
2013-06-20 22:06:39 +01:00
char payload[] = "123 ABCDEFGHIJKLMNOPQRSTUVWXYZ";
byte sendSize=0;
boolean requestACK = false;
2013-07-30 21:50:37 +01:00
SPIFlash flash(8, 0xEF30); //EF40 for 16mbit windbond chip
2013-06-20 22:06:39 +01:00
RFM69 radio;
void setup() {
Serial.begin(SERIAL_BAUD);
radio.initialize(FREQUENCY,NODEID,NETWORKID);
2013-08-16 02:40:56 +01:00
//radio.setHighPower(); //must uncomment for RFM69HW!
2013-06-20 22:06:39 +01:00
radio.encrypt(KEY);
char buff[50];
sprintf(buff, "\nTransmitting at %d Mhz...", FREQUENCY==RF69_433MHZ ? 433 : FREQUENCY==RF69_868MHZ ? 868 : 915);
Serial.println(buff);
2013-07-30 21:50:37 +01:00
if (flash.initialize())
Serial.println("SPI Flash Init OK!");
else
Serial.println("SPI Flash Init FAIL! (is chip present?)");
2013-06-20 22:06:39 +01:00
}
long lastPeriod = -1;
void loop() {
//process any serial input
if (Serial.available() > 0)
{
char input = Serial.read();
if (input >= 48 && input <= 57) //[0,9]
{
TRANSMITPERIOD = 100 * (input-48);
if (TRANSMITPERIOD == 0) TRANSMITPERIOD = 1000;
Serial.print("\nChanging delay to ");
Serial.print(TRANSMITPERIOD);
Serial.println("ms\n");
}
2013-07-30 21:50:37 +01:00
if (input == 'r') //d=dump register values
2013-06-20 22:06:39 +01:00
radio.readAllRegs();
2013-08-05 15:34:03 +01:00
//if (input == 'E') //E=enable encryption
// radio.encrypt(KEY);
//if (input == 'e') //e=disable encryption
// radio.encrypt(null);
2013-07-30 21:50:37 +01:00
if (input == 'd') //d=dump flash area
{
Serial.println("Flash content:");
int counter = 0;
while(counter<=256){
Serial.print(flash.readByte(counter++), HEX);
Serial.print('.');
}
while(flash.busy());
Serial.println();
}
if (input == 'e')
{
Serial.print("Erasing Flash chip ... ");
flash.chipErase();
while(flash.busy());
Serial.println("DONE");
}
if (input == 'i')
{
Serial.print("DeviceID: ");
word jedecid = flash.readDeviceId();
Serial.println(jedecid, HEX);
}
2013-06-20 22:06:39 +01:00
}
//check for any received packets
if (radio.receiveDone())
{
Serial.print('[');Serial.print(radio.SENDERID, DEC);Serial.print("] ");
for (byte i = 0; i < radio.DATALEN; i++)
Serial.print((char)radio.DATA[i]);
Serial.print(" [RX_RSSI:");Serial.print(radio.readRSSI());Serial.print("]");
if (radio.ACK_REQUESTED)
{
radio.sendACK();
2013-07-30 21:50:37 +01:00
Serial.print(" - ACK sent");
delay(10);
2013-06-20 22:06:39 +01:00
}
Blink(LED,5);
Serial.println();
}
int currPeriod = millis()/TRANSMITPERIOD;
if (currPeriod != lastPeriod)
{
lastPeriod=currPeriod;
Serial.print("Sending[");
Serial.print(sendSize);
Serial.print("]: ");
for(byte i = 0; i < sendSize; i++)
Serial.print((char)payload[i]);
if (radio.sendWithRetry(GATEWAYID, payload, sendSize))
Serial.print(" ok!");
else Serial.print(" nothing...");
// //manual ACK handling
// requestACK = ((sendSize % 3) == 0); //request ACK every 3rd xmission
// radio.send(GATEWAYID, payload, sendSize, requestACK);
// if (requestACK)
// {
// Serial.print(" - waiting for ACK...");
// if (waitForAck(GATEWAYID)) Serial.print("ok!");
// else Serial.print("nothing...");
// }
sendSize = (sendSize + 1) % 31;
Serial.println();
Blink(LED,3);
}
}
2013-07-30 21:50:37 +01:00
void Blink(byte PIN, int DELAY_MS)
2013-06-20 22:06:39 +01:00
{
pinMode(PIN, OUTPUT);
digitalWrite(PIN,HIGH);
2013-07-30 21:50:37 +01:00
delay(DELAY_MS);
2013-06-20 22:06:39 +01:00
digitalWrite(PIN,LOW);
}
//// wait a few milliseconds for proper ACK to me, return true if indeed received
//static bool waitForAck(byte theNodeID) {
// long now = millis();
// while (millis() - now <= ACK_TIME) {
// if (radio.ACKReceived(theNodeID))
// return true;
// }
// return false;
2013-08-05 15:34:03 +01:00
//}