diff --git a/RCSwitch.cpp b/RCSwitch.cpp index 1a6736e..6ef1c8f 100644 --- a/RCSwitch.cpp +++ b/RCSwitch.cpp @@ -87,7 +87,7 @@ enum { }; #if not defined( RCSwitchDisableReceiving ) -volatile unsigned long RCSwitch::nReceivedValue = 0; +volatile unsigned long long RCSwitch::nReceivedValue = 0; volatile unsigned int RCSwitch::nReceivedBitlength = 0; volatile unsigned int RCSwitch::nReceivedDelay = 0; volatile unsigned int RCSwitch::nReceivedProtocol = 0; @@ -468,12 +468,12 @@ void RCSwitch::sendTriState(const char* sCodeWord) { */ void RCSwitch::send(const char* sCodeWord) { // turn the tristate code word into the corresponding bit pattern, then send it - unsigned long code = 0; + unsigned long long code = 0; unsigned int length = 0; for (const char* p = sCodeWord; *p; p++) { - code <<= 1L; + code <<= 1LL; if (*p != '0') - code |= 1L; + code |= 1LL; length++; } this->send(code, length); @@ -484,7 +484,7 @@ void RCSwitch::send(const char* sCodeWord) { * bits are sent from MSB to LSB, i.e., first the bit at position length-1, * then the bit at position length-2, and so on, till finally the bit at position 0. */ -void RCSwitch::send(unsigned long code, unsigned int length) { +void RCSwitch::send(unsigned long long code, unsigned int length) { if (this->nTransmitterPin == -1) return; @@ -495,17 +495,17 @@ void RCSwitch::send(unsigned long code, unsigned int length) { this->disableReceive(); } #endif - + for (int nRepeat = 0; nRepeat < nRepeatTransmit; nRepeat++) { for (int i = length-1; i >= 0; i--) { - if (code & (1L << i)) + if (code & (1LL << i)) this->transmit(protocol.one); else this->transmit(protocol.zero); } this->transmit(protocol.syncFactor); } - + // Disable transmit after sending (i.e., for inverted protocols) digitalWrite(this->nTransmitterPin, LOW); @@ -570,7 +570,7 @@ void RCSwitch::resetAvailable() { RCSwitch::nReceivedValue = 0; } -unsigned long RCSwitch::getReceivedValue() { +unsigned long long RCSwitch::getReceivedValue() { return RCSwitch::nReceivedValue; } @@ -606,7 +606,7 @@ bool RECEIVE_ATTR RCSwitch::receiveProtocol(const int p, unsigned int changeCoun memcpy_P(&pro, &proto[p-1], sizeof(Protocol)); #endif - unsigned long code = 0; + unsigned long long code = 0; //Assuming the longer pulse length is the pulse captured in timings[0] const unsigned int syncLengthInPulses = ((pro.syncFactor.low) > (pro.syncFactor.high)) ? (pro.syncFactor.low) : (pro.syncFactor.high); const unsigned int delay = RCSwitch::timings[0] / syncLengthInPulses; @@ -632,14 +632,14 @@ bool RECEIVE_ATTR RCSwitch::receiveProtocol(const int p, unsigned int changeCoun const unsigned int firstDataTiming = (pro.invertedSignal) ? (2) : (1); for (unsigned int i = firstDataTiming; i < changeCount - 1; i += 2) { - code <<= 1; + code <<= 1LL; if (diff(RCSwitch::timings[i], delay * pro.zero.high) < delayTolerance && diff(RCSwitch::timings[i + 1], delay * pro.zero.low) < delayTolerance) { // zero } else if (diff(RCSwitch::timings[i], delay * pro.one.high) < delayTolerance && diff(RCSwitch::timings[i + 1], delay * pro.one.low) < delayTolerance) { // one - code |= 1; + code |= 1LL; } else { // Failed return false; diff --git a/RCSwitch.h b/RCSwitch.h index b7755e0..6e09bef 100644 --- a/RCSwitch.h +++ b/RCSwitch.h @@ -57,8 +57,8 @@ #endif // Number of maximum high/Low changes per packet. -// We can handle up to (unsigned long) => 32 bit * 2 H/L changes per bit + 2 for sync -#define RCSWITCH_MAX_CHANGES 67 +// We can handle up to (unsigned long) => 64 bit * 2 H/L changes per bit + 2 for sync +#define RCSWITCH_MAX_CHANGES 131 class RCSwitch { @@ -77,7 +77,7 @@ class RCSwitch { void switchOff(char sGroup, int nDevice); void sendTriState(const char* sCodeWord); - void send(unsigned long code, unsigned int length); + void send(unsigned long long code, unsigned int length); void send(const char* sCodeWord); #if not defined( RCSwitchDisableReceiving ) @@ -87,7 +87,7 @@ class RCSwitch { bool available(); void resetAvailable(); - unsigned long getReceivedValue(); + unsigned long long getReceivedValue(); unsigned int getReceivedBitlength(); unsigned int getReceivedDelay(); unsigned int getReceivedProtocol(); @@ -167,7 +167,7 @@ class RCSwitch { #if not defined( RCSwitchDisableReceiving ) static int nReceiveTolerance; - volatile static unsigned long nReceivedValue; + volatile static unsigned long long nReceivedValue; volatile static unsigned int nReceivedBitlength; volatile static unsigned int nReceivedDelay; volatile static unsigned int nReceivedProtocol; diff --git a/examples/ReceiveDemo_Advanced/output.ino b/examples/ReceiveDemo_Advanced/output.ino index 31e61ba..28fb966 100644 --- a/examples/ReceiveDemo_Advanced/output.ino +++ b/examples/ReceiveDemo_Advanced/output.ino @@ -1,22 +1,29 @@ static const char* bin2tristate(const char* bin); -static char * dec2binWzerofill(unsigned long Dec, unsigned int bitLength); +static char * dec2binWzerofill(unsigned long long Dec, unsigned int bitLength); -void output(unsigned long decimal, unsigned int length, unsigned int delay, unsigned int* raw, unsigned int protocol) { - - const char* b = dec2binWzerofill(decimal, length); - Serial.print("Decimal: "); - Serial.print(decimal); - Serial.print(" ("); - Serial.print( length ); - Serial.print("Bit) Binary: "); - Serial.print( b ); - Serial.print(" Tri-State: "); - Serial.print( bin2tristate( b) ); - Serial.print(" PulseLength: "); - Serial.print(delay); - Serial.print(" microseconds"); - Serial.print(" Protocol: "); - Serial.println(protocol); +void output(unsigned long long decimal, unsigned int length, unsigned int delay, unsigned int* raw, unsigned int protocol) { + if (decimal == 0) { + Serial.print("Unknown encoding."); + } else { + const char* b = dec2binWzerofill(decimal, length); + char buffer[100]; + Serial.print("Decimal: "); + sprintf(buffer, "%0ld", decimal/1000000L); + Serial.print(buffer); + sprintf(buffer, "%0ld", decimal%1000000L); + Serial.print(buffer); + Serial.print(" ("); + Serial.print( length ); + Serial.print("Bit) Binary: "); + Serial.print( b ); + Serial.print(" Tri-State: "); + Serial.print( bin2tristate( b) ); + Serial.print(" PulseLength: "); + Serial.print(delay); + Serial.print(" microseconds"); + Serial.print(" Protocol: "); + Serial.println(protocol); + } Serial.print("Raw data: "); for (unsigned int i=0; i<= length*2; i++) { @@ -48,18 +55,18 @@ static const char* bin2tristate(const char* bin) { return returnValue; } -static char * dec2binWzerofill(unsigned long Dec, unsigned int bitLength) { - static char bin[64]; +static char * dec2binWzerofill(unsigned long long Dec, unsigned int bitLength) { + static char bin[128]; unsigned int i=0; while (Dec > 0) { - bin[32+i++] = ((Dec & 1) > 0) ? '1' : '0'; + bin[64+i++] = ((Dec & 1) > 0) ? '1' : '0'; Dec = Dec >> 1; } for (unsigned int j = 0; j< bitLength; j++) { if (j >= bitLength - i) { - bin[j] = bin[ 31 + i - (j - (bitLength - i)) ]; + bin[j] = bin[ 63 + i - (j - (bitLength - i)) ]; } else { bin[j] = '0'; } diff --git a/examples/ReceiveDemo_Simple/ReceiveDemo_Simple.ino b/examples/ReceiveDemo_Simple/ReceiveDemo_Simple.ino index bb10763..ea41580 100644 --- a/examples/ReceiveDemo_Simple/ReceiveDemo_Simple.ino +++ b/examples/ReceiveDemo_Simple/ReceiveDemo_Simple.ino @@ -15,14 +15,23 @@ void setup() { void loop() { if (mySwitch.available()) { + unsigned long long value = mySwitch.getReceivedValue(); + char buffer[100]; - Serial.print("Received "); - Serial.print( mySwitch.getReceivedValue() ); - Serial.print(" / "); - Serial.print( mySwitch.getReceivedBitlength() ); - Serial.print("bit "); - Serial.print("Protocol: "); - Serial.println( mySwitch.getReceivedProtocol() ); + if (value == 0) { + Serial.print("Unknown encoding"); + } else { + Serial.print("Received "); + sprintf(buffer, "%0ld", value/1000000L); + Serial.print(buffer); + sprintf(buffer, "%0ld", value%1000000L); + Serial.print(buffer); + Serial.print(" / "); + Serial.print( mySwitch.getReceivedBitlength() ); + Serial.print("bit "); + Serial.print("Protocol: "); + Serial.println( mySwitch.getReceivedProtocol() ); + } mySwitch.resetAvailable(); }