Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependencies: SoftSerial SDFileSystem mbed wave_player
Diff: MySoftSerial.cpp
- Revision:
- 21:2a91babf5a6d
- Parent:
- 20:d2a8daeb6eb7
- Child:
- 22:c821bfae25d7
--- a/MySoftSerial.cpp Sat May 13 16:21:17 2017 +0200
+++ b/MySoftSerial.cpp Tue May 16 19:29:56 2017 +0000
@@ -5,15 +5,25 @@
#include "MySoftSerial.h"
#include "Manchester.h"
-uint32_t overhead_us = 200 * 1000000 / SystemCoreClock;
MySoftSerial::MySoftSerial(PinName TX, PinName RX, const char *name) : SoftSerial(TX, RX, name) {
- max_time_between_transmission_us = 100000;
+ max_time_between_transmission_us = 10000;
calc_required_correction_symbols();
format(16, SoftSerial::None, 1);
start_bits = 4;
dc_offset_timer.reset();
dc_offset_timer.start();
+ overhead_us = 200 * 1000000 / SystemCoreClock;
+
+ txticker.detach();
+ rxticker.detach();
+ if (TX != NC) {
+ txticker.attach(this, &MySoftSerial::tx_handler);
+ }
+ if (RX != NC) {
+ rxticker.attach(this, &MySoftSerial::rx_handler);
+ rx->fall(this, &MySoftSerial::rx_gpio_irq_handler);
+ }
}
void MySoftSerial::calc_required_correction_symbols() {
@@ -35,6 +45,16 @@
return _putc(c);
}
+int MySoftSerial::_putc(int c)
+{
+ while(!writeable());
+ prepare_tx(c);
+ tx_bit = 0;
+ txticker.prime();
+ tx_handler();
+ return 0;
+}
+
int MySoftSerial::getc() {
int character = _getc();
return Manchester::decode(character);
@@ -79,6 +99,7 @@
start_bit = 1; // start from second bit
rx_bit = 0;
rx_error = false;
+ printf("q\n");
}
void MySoftSerial::rx_detect_start(void){
@@ -93,26 +114,92 @@
break;
case 1:
ok = val==1;
+ printf("a\n");
break;
case 2:
ok = val==0;
+ printf("b\n");
break;
case 3:
+ printf("c\n");
ok = val==1;
- rxticker.attach(this, &MySoftSerial::tx_handler);
+ rxticker.attach(this, &MySoftSerial::rx_handler);
break;
default:
+ printf("d\n");
ok = false;
}
if(ok){
- rx_bit++;
+ start_bit++;
rxticker.setNext(bit_period);
} else {
// start pattern was not correct, this is not a data packet
rxticker.detach();
- rx->fall(this, &SoftSerial::rx_gpio_irq_handler);
+ rx->fall(this, &MySoftSerial::rx_gpio_irq_handler);
+ }
+}
+
+void MySoftSerial::rx_handler(void) {
+ //Receive data
+ printf("%i\n",rx_bit);
+ int val = rx->read();
+
+ rxticker.setNext(bit_period);
+ rx_bit++;
+
+
+ if (rx_bit <= _bits) {
+ read_buffer |= val << (rx_bit - 1);
+ return;
}
+
+ //Receive parity
+ bool parity_count;
+ if (rx_bit == _bits + 1) {
+ switch (_parity) {
+ case Forced1:
+ if (val == 0)
+ rx_error = true;
+ return;
+ case Forced0:
+ if (val == 1)
+ rx_error = true;
+ return;
+ case Even:
+ case Odd:
+ parity_count = val;
+ for (int i = 0; i<_bits; i++) {
+ if (((read_buffer >> i) & 0x01) == 1)
+ parity_count = !parity_count;
+ }
+ if ((parity_count) && (_parity == Even))
+ rx_error = true;
+ if ((!parity_count) && (_parity == Odd))
+ rx_error = true;
+ return;
+ }
+ }
+
+ //Receive stop
+ if (rx_bit < _bits + (bool)_parity + _stop_bits) {
+ if (!val)
+ rx_error = true;
+ return;
+ }
+
+ //The last stop bit
+ if (!val)
+ rx_error = true;
+
+ if (!rx_error) {
+ out_valid = true;
+ out_buffer = read_buffer;
+ fpointer[RxIrq].call();
+ }
+ read_buffer = 0;
+ rxticker.detach();
+ rx->fall(this, &MySoftSerial::rx_gpio_irq_handler);
}
void MySoftSerial::format(int bits, SoftSerial::Parity parity, int stop_bits) {