first CAN light ;)
This commit is contained in:
parent
6865f4c9e5
commit
662f9f3a60
130
src/CANode.cpp
130
src/CANode.cpp
@ -17,12 +17,14 @@
|
|||||||
|
|
||||||
// Configurations
|
// Configurations
|
||||||
// Misc
|
// Misc
|
||||||
|
#define N_EVENTS 64
|
||||||
|
#define N_SWITCHES 64
|
||||||
#define DEBUG 0
|
#define DEBUG 0
|
||||||
#define LED 13
|
#define LED 13
|
||||||
// Metro
|
// Metro
|
||||||
#define METRO_CAN_tick 1 // 20 millisecond
|
#define METRO_CAN_tick 1 // 20 millisecond
|
||||||
#define METRO_OW_read_tick 20 // 20 millisecond
|
#define METRO_OW_read_tick 20 // 20 millisecond
|
||||||
#define METRO_OW_search_tick 1000 // 1000 millisecond
|
#define METRO_OW_search_tick 10000 // 1000 millisecond
|
||||||
// CAN bus
|
// CAN bus
|
||||||
#define CAN_speed 125000
|
#define CAN_speed 125000
|
||||||
#define CAN_RS_PIN 2
|
#define CAN_RS_PIN 2
|
||||||
@ -43,8 +45,8 @@
|
|||||||
|
|
||||||
#define DS2406_BUF_LEN 10
|
#define DS2406_BUF_LEN 10
|
||||||
// Definitions
|
// Definitions
|
||||||
static OW_switch_t switches;
|
static OW_switch_t switches[N_SWITCHES];
|
||||||
|
static event_t events[N_EVENTS];
|
||||||
|
|
||||||
|
|
||||||
// Initialisation
|
// Initialisation
|
||||||
@ -67,13 +69,13 @@ FlexCAN CANbus(CAN_speed);
|
|||||||
// OneWire
|
// OneWire
|
||||||
uint8_t addr[8];
|
uint8_t addr[8];
|
||||||
uint8_t buffer[DS2406_BUF_LEN];
|
uint8_t buffer[DS2406_BUF_LEN];
|
||||||
uint8_t readout,tmp;
|
uint8_t readout,trig_event,event_idx,tmp;
|
||||||
OneWire OW_1(OW_pin);
|
OneWire OW_1(OW_pin);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
static CAN_message_t msg,rxmsg;
|
static CAN_message_t txmsg,rxmsg;
|
||||||
static uint8_t hex[17] = "0123456789abcdef";
|
static uint8_t hex[17] = "0123456789abcdef";
|
||||||
|
|
||||||
int txCount,rxCount;
|
int txCount,rxCount;
|
||||||
@ -128,17 +130,28 @@ uint8_t read_DS2406(uint8_t* addr) {
|
|||||||
void setup(void)
|
void setup(void)
|
||||||
{
|
{
|
||||||
// Misc
|
// Misc
|
||||||
switches.nick = 1;
|
switches[0].nick = 1;
|
||||||
switches.addr[0] = 0x12,
|
switches[0].addr[0] = 0x12,
|
||||||
switches.addr[1] = 0x5b;
|
switches[0].addr[1] = 0x5b;
|
||||||
switches.addr[2] = 0x27;
|
switches[0].addr[2] = 0x27;
|
||||||
switches.addr[3] = 0x50;
|
switches[0].addr[3] = 0x50;
|
||||||
switches.addr[4] = 0x0;
|
switches[0].addr[4] = 0x0;
|
||||||
switches.addr[5] = 0x0;
|
switches[0].addr[5] = 0x0;
|
||||||
switches.addr[6] = 0x0;
|
switches[0].addr[6] = 0x0;
|
||||||
switches.addr[7] = 0x26;
|
switches[0].addr[7] = 0x26;
|
||||||
switches.state = 0x60;
|
switches[0].event_id[0] = 0x01;
|
||||||
//my_sw.event[0] = { 0x01020304, 2, { 0xde, 0xad }};
|
switches[0].event_id[1] = 0x02;
|
||||||
|
|
||||||
|
events[0].id =0x01;
|
||||||
|
events[0].telegram.id = 0x0102DEAD;
|
||||||
|
events[0].telegram.len = 2;
|
||||||
|
events[0].telegram.buf[0] = 0xDE;
|
||||||
|
events[0].telegram.buf[1] = 0xAD;
|
||||||
|
events[1].id =0x02;
|
||||||
|
events[1].telegram.id = 0x0204BEEF;
|
||||||
|
events[1].telegram.len = 2;
|
||||||
|
events[1].telegram.buf[0] = 0xBE;
|
||||||
|
events[1].telegram.buf[1] = 0xEF;
|
||||||
|
|
||||||
//{ 0x02040608, 2, { 0xbe, 0xef }}};
|
//{ 0x02040608, 2, { 0xbe, 0xef }}};
|
||||||
|
|
||||||
@ -150,6 +163,9 @@ void setup(void)
|
|||||||
pinMode(CAN_RS_PIN,OUTPUT);
|
pinMode(CAN_RS_PIN,OUTPUT);
|
||||||
digitalWrite(CAN_RS_PIN,0);
|
digitalWrite(CAN_RS_PIN,0);
|
||||||
CANbus.begin();
|
CANbus.begin();
|
||||||
|
txmsg.ext = 1;
|
||||||
|
txmsg.timeout = 100;
|
||||||
|
|
||||||
|
|
||||||
delay(100);
|
delay(100);
|
||||||
Serial.println(F("Hello Teensy 3.2 CANode awakes."));
|
Serial.println(F("Hello Teensy 3.2 CANode awakes."));
|
||||||
@ -164,50 +180,41 @@ void loop(void)
|
|||||||
{
|
{
|
||||||
// service software timers based on Metro tick
|
// service software timers based on Metro tick
|
||||||
if ( METRO_OW_search.check() ) {
|
if ( METRO_OW_search.check() ) {
|
||||||
//Serial.print("Beginning Search...\n");
|
|
||||||
OW_1.reset_search();
|
OW_1.reset_search();
|
||||||
// Assume we can't find something until we prove otherwise.
|
|
||||||
// bool foundDevice = false;
|
|
||||||
|
|
||||||
while(OW_1.search(addr) == 1) {
|
while(OW_1.search(addr) == 1) {
|
||||||
if ( OneWire::crc8( addr, 7) != addr[7]) {
|
if ( OneWire::crc8( addr, 7) != addr[7]) {
|
||||||
Serial.print("CRC is not valid!\n");
|
Serial.print("CRC is not valid!\n");
|
||||||
delay(100);
|
delay(100);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Serial.print("Found a device: ");
|
Serial.print("Found a device: ");
|
||||||
print_OW_Device(addr);
|
print_OW_Device(addr);
|
||||||
Serial.println("");
|
Serial.println("");
|
||||||
|
|
||||||
|
|
||||||
// At this point, we know we have a DS2406. Blink it.
|
|
||||||
//if(addr[0] == DS2406_FAMILY) {
|
|
||||||
// foundDevice = true;
|
|
||||||
// digitalWrite(13, HIGH);
|
|
||||||
// tmp = read_DS2406(addr);
|
|
||||||
// bool pioA = tmp & 0x04;
|
|
||||||
// bool pioB = tmp & 0x08;
|
|
||||||
// digitalWrite(led, pioA)i;
|
|
||||||
// }
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
if (METRO_OW_read.check() ) {
|
if (METRO_OW_read.check() ) {
|
||||||
bool action[2];
|
bool action[2];
|
||||||
readout = read_DS2406(switches.addr);
|
readout = read_DS2406(switches[0].addr);
|
||||||
if (switches.state != readout) {
|
if (switches[0].state != readout) {
|
||||||
tmp = readout ^ switches.state;
|
tmp = readout ^ switches[0].state;
|
||||||
switches.state = readout;
|
switches[0].state = readout;
|
||||||
action[0] = tmp & 0x04;
|
action[0] = tmp & 0x04;
|
||||||
action[1] = tmp & 0x08;
|
action[1] = tmp & 0x08;
|
||||||
}
|
}
|
||||||
if (action[0]) { Serial.print("pioA toggled"); digitalWrite(led, !digitalRead(led));}
|
if (action[0]) {
|
||||||
if (action[1]) { Serial.print("pioB toggled"); digitalWrite(led, !digitalRead(led));}
|
Serial.print("pioA toggled");
|
||||||
|
digitalWrite(led, !digitalRead(led));
|
||||||
|
trig_event = switches[0].event_id[0];
|
||||||
|
// might need queuing
|
||||||
|
event_idx = 0;
|
||||||
|
}
|
||||||
|
if (action[1]) {
|
||||||
|
Serial.print("pioB toggled");
|
||||||
|
digitalWrite(led, !digitalRead(led));
|
||||||
|
trig_event= switches[0].event_id[1];
|
||||||
|
event_idx = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if ( METRO_CAN.check() ) {
|
if ( METRO_CAN.check() ) {
|
||||||
if ( txTimer ) {
|
if ( txTimer ) {
|
||||||
--txTimer;
|
--txTimer;
|
||||||
@ -216,7 +223,17 @@ void loop(void)
|
|||||||
--rxTimer;
|
--rxTimer;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if ( txmsg.len == 0 && trig_event != 0 ) {
|
||||||
|
if ( events[event_idx].id == trig_event ) {
|
||||||
|
txmsg.id = events[event_idx].telegram.id;
|
||||||
|
txmsg.len = events[event_idx].telegram.len;
|
||||||
|
for (uint i=0;i<txmsg.len;i++){
|
||||||
|
txmsg.buf[i] = events[event_idx].telegram.buf[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ( events[event_idx].id == 0) { trig_event = 0; }
|
||||||
|
event_idx++;
|
||||||
|
}
|
||||||
// if not time-delayed, read CAN messages and print 1st byte
|
// if not time-delayed, read CAN messages and print 1st byte
|
||||||
if ( !rxTimer ) {
|
if ( !rxTimer ) {
|
||||||
while ( CANbus.read(rxmsg) ) {
|
while ( CANbus.read(rxmsg) ) {
|
||||||
@ -230,27 +247,32 @@ void loop(void)
|
|||||||
if ( !txTimer ) {
|
if ( !txTimer ) {
|
||||||
// if frames were received, print the count
|
// if frames were received, print the count
|
||||||
if ( rxCount ) {
|
if ( rxCount ) {
|
||||||
#if DEBUG
|
//#if DEBUG
|
||||||
Serial.write('=');
|
Serial.write('=');
|
||||||
Serial.print(rxCount);
|
Serial.print(rxCount);
|
||||||
Serial.print(",Hello=");
|
Serial.print(",Hello=");
|
||||||
Serial.print(rxmsg.id,HEX);
|
Serial.print(rxmsg.id,HEX);
|
||||||
#endif
|
//#endif
|
||||||
rxCount = 0;
|
rxCount = 0;
|
||||||
}
|
}
|
||||||
txTimer = 100;//milliseconds
|
txTimer = 100;//milliseconds
|
||||||
msg.len = 8;
|
//txmsg.len = 8;
|
||||||
msg.id = 0x222;
|
//txmsg.id = 0x222;
|
||||||
for( int idx=0; idx<8; ++idx ) {
|
//for( int idx=0; idx<8; ++idx ) {
|
||||||
msg.buf[idx] = '0'+idx;
|
// txmsg.buf[idx] = '0'+idx;
|
||||||
}
|
//}
|
||||||
// send 6 at a time to force tx buffering
|
// send 6 at a time to force tx buffering
|
||||||
txCount = 16;
|
// txCount = 16;
|
||||||
//digitalWrite(led, 1);
|
//digitalWrite(led, 1);
|
||||||
// Serial.println(".");
|
// Serial.println(".");
|
||||||
while ( txCount-- ) {
|
//while ( txCount-- ) {
|
||||||
CANbus.write(msg);
|
if (txmsg.len != 0){
|
||||||
msg.buf[0]++;
|
Serial.print("Sending to CAN");
|
||||||
|
Serial.print(txmsg.id,HEX);
|
||||||
|
CANbus.write(txmsg);
|
||||||
|
txmsg.buf[0]++;
|
||||||
|
//}
|
||||||
|
txmsg.len = 0;
|
||||||
}
|
}
|
||||||
// digitalWrite(led, 0);
|
// digitalWrite(led, 0);
|
||||||
// time delay to force some rx data queue use
|
// time delay to force some rx data queue use
|
||||||
|
@ -10,5 +10,10 @@ typedef struct OW_switch_t {
|
|||||||
uint8_t nick;
|
uint8_t nick;
|
||||||
uint8_t addr[8];
|
uint8_t addr[8];
|
||||||
uint8_t state;
|
uint8_t state;
|
||||||
CAN_telegram_t event[2];
|
uint8_t event_id[2];
|
||||||
} OW_switch_t;
|
} OW_switch_t;
|
||||||
|
|
||||||
|
typedef struct event_t {
|
||||||
|
uint8_t id;
|
||||||
|
CAN_telegram_t telegram;
|
||||||
|
} event_t;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user