Sigfox Communication library, allowing you to use any kind of UART able Sigfox Transmitter
Dependents: TestVirtualisation
Diff: sigfox.cpp
- Revision:
- 3:3ef537a95c15
- Parent:
- 2:975b82a3cde0
--- a/sigfox.cpp Sat Mar 12 16:00:57 2016 +0000 +++ b/sigfox.cpp Tue Jan 15 15:18:38 2019 +0000 @@ -5,19 +5,22 @@ Sigfox_ Sigfox; Sigfox_::Sigfox_() { - Serial device(PIN_RX, PIN_TX); + Serial device(PIN_TX, PIN_RX); _lastSend=-1; } uint8_t Sigfox_::_nextReturn() { - Serial device(PIN_RX, PIN_TX); + Serial sc(SERIAL_TX, SERIAL_RX, 9600); + Serial device(PIN_TX, PIN_RX); char fstChar = device.getc(); - while(device.getc() != ';'); + sc.printf("hola\n"); + // while(device.getc() != ';'); + sc.printf("momo\n"); return fstChar; } void Sigfox_::begin () { - Serial device(PIN_RX, PIN_TX); + Serial device(PIN_TX, PIN_RX); device.putc((uint8_t)'\0'); device.putc((uint8_t)';'); @@ -29,28 +32,31 @@ } bool Sigfox_::isReady() { - Serial device(PIN_RX, PIN_TX); + Serial device(PIN_TX, PIN_RX); - unsigned long currentTime = millis(); + /* unsigned long currentTime = millis(); if(currentTime >= _lastSend && (currentTime - _lastSend) <= 600000) { return false; - } + }*/ // Time is ok, ask the modem's status device.putc((uint8_t)'\0'); device.putc((uint8_t)'A'); device.putc((uint8_t)'T'); device.putc('\r'); //device.putc((uint8_t)';'); - - //return _nextReturn() == OK; + + + // return _nextReturn() == OK; return true; } bool Sigfox_::send(const void* data, uint8_t len) { + Serial sc(SERIAL_TX, SERIAL_RX, 9600); + sc.printf("sending ... \n"); + uint8_t* bytes = (uint8_t*)data; - _lastSend = millis(); - - Serial device(PIN_RX, PIN_TX); + // _lastSend = millis(); + Serial device(PIN_TX, PIN_RX); device.putc((uint8_t)'\0'); device.putc((uint8_t)'A'); device.putc((uint8_t)'T'); @@ -59,22 +65,25 @@ device.putc((uint8_t)'F'); device.putc((uint8_t)'='); + sc.printf("coucou 0\n"); for(uint8_t i = 0; i < len; ++i) { device.putc(bytes[i]); } device.putc('\r'); - - uint8_t ok = _nextReturn(); + sc.printf("coucou 1 \n"); + /* uint8_t ok = _nextReturn(); if(ok == OK) { _nextReturn(); //SENT return true; } - return false; + sc.printf("coucou 2\n"); + return false;*/ + return true; } unsigned long Sigfox_::getID() { unsigned long id = 0; - Serial device(PIN_RX, PIN_TX); + Serial device(PIN_TX, PIN_RX); device.putc((uint8_t)'\0'); device.putc((uint8_t)'A'); device.putc((uint8_t)'T'); @@ -106,7 +115,7 @@ unsigned long Sigfox_::getPAC() { unsigned long id = 0; - Serial device(PIN_RX, PIN_TX); + Serial device(PIN_TX, PIN_RX); device.putc((uint8_t)'\0'); device.putc((uint8_t)'A'); device.putc((uint8_t)'T'); @@ -127,11 +136,11 @@ for(uint8_t j = 0; j < i; ++j) { id += response[j] << ((i-3-j) * 16); } - return true; + return id; } bool Sigfox_::setPowerMode(uint8_t power) { - Serial device(PIN_RX, PIN_TX); + Serial device(PIN_TX, PIN_RX); device.putc((uint8_t)'\0'); device.putc((uint8_t)'A'); device.putc((uint8_t)'T');