MODSERIAL with support for more devices

Dependents:   1D-Pong BMT-K9_encoder BMT-K9-Regelaar programma_filter ... more

Check the cookbook page for more information: https://mbed.org/cookbook/MODSERIAL

Did you add a device? Please send a pull request so we can keep everything in one library instead of many copies. In that case also send a PM, since currently mbed does not inform of new pull requests. I will then also add you to the developers of this library so you can do other changes directly.

Committer:
Sissors
Date:
Sun May 07 16:26:36 2017 +0000
Revision:
44:a3b2bc878529
Parent:
43:8c8d13e1840b
Used callback functions to attach to Serial, to remove compilation warnings

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Sissors 27:9c93ce7cb9d8 1 #ifdef TARGET_LPC1768
Sissors 27:9c93ce7cb9d8 2 #include "MODSERIAL.h"
Sissors 27:9c93ce7cb9d8 3
Sissors 27:9c93ce7cb9d8 4
Sissors 27:9c93ce7cb9d8 5 void MODSERIAL::setBase(void ) {
cduck 43:8c8d13e1840b 6 #if DEVICE_SERIAL_ASYNCH
cduck 43:8c8d13e1840b 7 switch( _serial.serial.index ) {
cduck 43:8c8d13e1840b 8 #else
Sissors 27:9c93ce7cb9d8 9 switch( _serial.index ) {
cduck 43:8c8d13e1840b 10 #endif
Sissors 27:9c93ce7cb9d8 11 case 0: _base = LPC_UART0; _IRQ = UART0_IRQn; break;
Sissors 27:9c93ce7cb9d8 12 case 1: _base = LPC_UART1; _IRQ = UART1_IRQn; break;
Sissors 27:9c93ce7cb9d8 13 case 2: _base = LPC_UART2; _IRQ = UART2_IRQn; break;
Sissors 27:9c93ce7cb9d8 14 case 3: _base = LPC_UART3; _IRQ = UART3_IRQn; break;
Sissors 27:9c93ce7cb9d8 15 default: _base = NULL; _IRQ = (IRQn_Type)NULL; break;
Sissors 27:9c93ce7cb9d8 16 }
Sissors 27:9c93ce7cb9d8 17 }
Sissors 27:9c93ce7cb9d8 18
Sissors 28:76793a84f9e5 19 void MODSERIAL::initDevice(void) {
Sissors 28:76793a84f9e5 20 ((LPC_UART_TypeDef*)_base)->FCR = (1UL<<0) + (1UL<<1) + (1UL<<2);
Sissors 28:76793a84f9e5 21 }
Sissors 28:76793a84f9e5 22
Sissors 27:9c93ce7cb9d8 23 bool MODSERIAL::txIsBusy( void )
Sissors 27:9c93ce7cb9d8 24 {
Sissors 33:a65f89de75c5 25 return ( (((LPC_UART_TypeDef*)_base)->LSR & ( 1UL << 6 )) == 0 ) ? true : false;
Sissors 27:9c93ce7cb9d8 26 }
Sissors 27:9c93ce7cb9d8 27
Sissors 27:9c93ce7cb9d8 28 #endif