Inherit from Serial and use software buffers for TX and RX. This allows the UART peripherals to operate in a IRQ driven mode. Overrides most (but not all) stdio functions as Serial did
Dependents: buffered_serial_test BLE_Police_HRM evena_BLE_Police_HRM df-2014-workshop-rfid-case-generator-k64f ... more
Example
#include "mbed.h"
#include "BufferedSerial.h"
BufferedSerial pc(USBTX, USBRX);
int main()
{
pc.baud(115200);
while(1)
{
Timer s;
s.start();
pc.printf("Hello World - buff\n");
int buffered_time = s.read_us();
wait(0.1f); // give time for the buffer to empty
s.reset();
printf("Hello World - poll\n");
int polled_time = s.read_us();
s.stop();
wait(0.1f); // give time for the buffer to empty
pc.printf("printf buffered took %d us\n", buffered_time);
pc.printf("printf polled took %d us\n", polled_time);
wait(0.5f);
}
}
Diff: BufferedSerial.cpp
- Revision:
- 11:779304f9c5d2
- Parent:
- 10:9ee15ae3d1a3
- Child:
- 13:c17c532bc4f8
diff -r 9ee15ae3d1a3 -r 779304f9c5d2 BufferedSerial.cpp
--- a/BufferedSerial.cpp Wed Jan 07 18:37:11 2015 +0000
+++ b/BufferedSerial.cpp Sun Jul 26 21:53:11 2015 +0000
@@ -24,9 +24,9 @@
#include <stdarg.h>
BufferedSerial::BufferedSerial(PinName tx, PinName rx, uint32_t buf_size, uint32_t tx_multiple, const char* name)
- : SERIAL_BASE(tx, rx) , _rxbuf(buf_size), _txbuf((uint32_t)(tx_multiple*buf_size))
+ : RawSerial(tx, rx) , _rxbuf(buf_size), _txbuf((uint32_t)(tx_multiple*buf_size))
{
- SERIAL_BASE::attach(this, &BufferedSerial::rxIrq, Serial::RxIrq);
+ RawSerial::attach(this, &BufferedSerial::rxIrq, Serial::RxIrq);
this->_buf_size = buf_size;
this->_tx_multiple = tx_multiple;
return;
@@ -34,8 +34,8 @@
BufferedSerial::~BufferedSerial(void)
{
- SERIAL_BASE::attach(NULL, SERIAL_BASE::RxIrq);
- SERIAL_BASE::attach(NULL, SERIAL_BASE::TxIrq);
+ RawSerial::attach(NULL, RawSerial::RxIrq);
+ RawSerial::attach(NULL, RawSerial::TxIrq);
return;
}
@@ -135,7 +135,7 @@
serial_putc(&_serial, (int)_txbuf.get());
} else {
// disable the TX interrupt when there is nothing left to send
- SERIAL_BASE::attach(NULL, SERIAL_BASE::TxIrq);
+ RawSerial::attach(NULL, RawSerial::TxIrq);
break;
}
}
@@ -147,9 +147,9 @@
{
// if already busy then the irq will pick this up
if(serial_writable(&_serial)) {
- SERIAL_BASE::attach(NULL, SERIAL_BASE::TxIrq); // make sure not to cause contention in the irq
+ RawSerial::attach(NULL, RawSerial::TxIrq); // make sure not to cause contention in the irq
BufferedSerial::txIrq(); // only write to hardware in one place
- SERIAL_BASE::attach(this, &BufferedSerial::txIrq, SERIAL_BASE::TxIrq);
+ RawSerial::attach(this, &BufferedSerial::txIrq, RawSerial::TxIrq);
}
return;
Sam Grove

