|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184 |
- // RHGenericDriver.cpp
- //
- // Copyright (C) 2014 Mike McCauley
- // $Id: RHGenericDriver.cpp,v 1.19 2015/12/11 01:10:24 mikem Exp $
-
- #include <RHGenericDriver.h>
-
- RHGenericDriver::RHGenericDriver()
- :
- _mode(RHModeInitialising),
- _thisAddress(RH_BROADCAST_ADDRESS),
- _txHeaderTo(RH_BROADCAST_ADDRESS),
- _txHeaderFrom(RH_BROADCAST_ADDRESS),
- _txHeaderId(0),
- _txHeaderFlags(0),
- _rxBad(0),
- _rxGood(0),
- _txGood(0)
- {
- }
-
- bool RHGenericDriver::init()
- {
- return true;
- }
-
- // Blocks until a valid message is received
- void RHGenericDriver::waitAvailable()
- {
- while (!available())
- YIELD;
- }
-
- // Blocks until a valid message is received or timeout expires
- // Return true if there is a message available
- // Works correctly even on millis() rollover
- bool RHGenericDriver::waitAvailableTimeout(uint16_t timeout)
- {
- unsigned long starttime = millis();
- while ((millis() - starttime) < timeout)
- {
- if (available())
- {
- return true;
- }
- YIELD;
- }
- return false;
- }
-
- bool RHGenericDriver::waitPacketSent()
- {
- while (_mode == RHModeTx)
- YIELD; // Wait for any previous transmit to finish
- return true;
- }
-
- bool RHGenericDriver::waitPacketSent(uint16_t timeout)
- {
- unsigned long starttime = millis();
- while ((millis() - starttime) < timeout)
- {
- if (_mode != RHModeTx) // Any previous transmit finished?
- return true;
- YIELD;
- }
- return false;
- }
-
- void RHGenericDriver::setPromiscuous(bool promiscuous)
- {
- _promiscuous = promiscuous;
- }
-
- void RHGenericDriver::setThisAddress(uint8_t address)
- {
- _thisAddress = address;
- }
-
- void RHGenericDriver::setHeaderTo(uint8_t to)
- {
- _txHeaderTo = to;
- }
-
- void RHGenericDriver::setHeaderFrom(uint8_t from)
- {
- _txHeaderFrom = from;
- }
-
- void RHGenericDriver::setHeaderId(uint8_t id)
- {
- _txHeaderId = id;
- }
-
- void RHGenericDriver::setHeaderFlags(uint8_t set, uint8_t clear)
- {
- _txHeaderFlags &= ~clear;
- _txHeaderFlags |= set;
- }
-
- uint8_t RHGenericDriver::headerTo()
- {
- return _rxHeaderTo;
- }
-
- uint8_t RHGenericDriver::headerFrom()
- {
- return _rxHeaderFrom;
- }
-
- uint8_t RHGenericDriver::headerId()
- {
- return _rxHeaderId;
- }
-
- uint8_t RHGenericDriver::headerFlags()
- {
- return _rxHeaderFlags;
- }
-
- int8_t RHGenericDriver::lastRssi()
- {
- return _lastRssi;
- }
-
- RHGenericDriver::RHMode RHGenericDriver::mode()
- {
- return _mode;
- }
-
- void RHGenericDriver::setMode(RHMode mode)
- {
- _mode = mode;
- }
-
- bool RHGenericDriver::sleep()
- {
- return false;
- }
-
- // Diagnostic help
- void RHGenericDriver::printBuffer(const char* prompt, const uint8_t* buf, uint8_t len)
- {
- uint8_t i;
-
- #ifdef RH_HAVE_SERIAL
- Serial.println(prompt);
- for (i = 0; i < len; i++)
- {
- if (i % 16 == 15)
- Serial.println(buf[i], HEX);
- else
- {
- Serial.print(buf[i], HEX);
- Serial.print(' ');
- }
- }
- Serial.println("");
- #endif
- }
-
- uint16_t RHGenericDriver::rxBad()
- {
- return _rxBad;
- }
-
- uint16_t RHGenericDriver::rxGood()
- {
- return _rxGood;
- }
-
- uint16_t RHGenericDriver::txGood()
- {
- return _txGood;
- }
-
- #if (RH_PLATFORM == RH_PLATFORM_ARDUINO) && defined(RH_PLATFORM_ATTINY)
- // Tinycore does not have __cxa_pure_virtual, so without this we
- // get linking complaints from the default code generated for pure virtual functions
- extern "C" void __cxa_pure_virtual()
- {
- while (1);
- }
- #endif
|