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.
Revision 46:d2a5e26fd658, committed 2019-05-05
- Comitter:
- riaancillie
- Date:
- Sun May 05 14:57:11 2019 +0000
- Parent:
- 45:da0788f0bd77
- Commit message:
- Added support for target NUCLEO_F103RB
Changed in this revision
diff -r da0788f0bd77 -r d2a5e26fd658 Device/MODSERIALNUCLEO_F103RB.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/Device/MODSERIALNUCLEO_F103RB.cpp Sun May 05 14:57:11 2019 +0000 @@ -0,0 +1,24 @@ +#ifdef TARGET_NUCLEO_F103RB +#include "MODSERIAL.h" + +void MODSERIAL::setBase(void ) { +#if DEVICE_SERIAL_ASYNCH +switch( _serial.serial.index ) { +#else +switch( _serial.index ) { +#endif + case 0: _base = USART1; _IRQ = USART1_IRQn; break; + case 1: _base = USART2; _IRQ = USART2_IRQn; break; + case 2: _base = USART3; _IRQ = USART3_IRQn; break; + default: _base = NULL; _IRQ = (IRQn_Type)NULL; break; + } +} + +void MODSERIAL::initDevice(void) {}; + +bool MODSERIAL::txIsBusy( void ) +{ + return ( (((USART_TypeDef*)_base)->SR & ( 1UL << 6 )) == 0 ) ? true : false; +} + +#endif \ No newline at end of file
diff -r da0788f0bd77 -r d2a5e26fd658 Device/MODSERIAL_NUCLEO_F103RB.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/Device/MODSERIAL_NUCLEO_F103RB.h Sun May 05 14:57:11 2019 +0000 @@ -0,0 +1,20 @@ +#if defined(TARGET_NUCLEO_F103RB) + +#define MODSERIAL_IRQ_REG ((USART_TypeDef*)_base)->CR1 +#define DISABLE_TX_IRQ MODSERIAL_IRQ_REG &= ~USART_CR1_TXEIE +#define DISABLE_RX_IRQ MODSERIAL_IRQ_REG &= ~USART_CR1_RXNEIE +#define ENABLE_TX_IRQ MODSERIAL_IRQ_REG |= USART_CR1_TXEIE +#define ENABLE_RX_IRQ MODSERIAL_IRQ_REG |= USART_CR1_RXNEIE + +#define MODSERIAL_READ_REG ((USART_TypeDef*)_base)->DR +#define MODSERIAL_WRITE_REG ((USART_TypeDef*)_base)->DR +#define MODSERIAL_READABLE ((((USART_TypeDef*)_base)->SR & USART_SR_RXNE) != 0) +#define MODSERIAL_WRITABLE ((((USART_TypeDef*)_base)->SR & USART_SR_TXE) != 0) + +#define RESET_TX_FIFO while(0 == 1) +#define RESET_RX_FIFO while(MODSERIAL_READABLE) char dummy = MODSERIAL_READ_REG + +#define RX_IRQ_ENABLED ((MODSERIAL_IRQ_REG & USART_CR1_RXNEIE) != 0) +#define TX_IRQ_ENABLED ((MODSERIAL_IRQ_REG & USART_CR1_TXEIE) != 0) + +#endif \ No newline at end of file
diff -r da0788f0bd77 -r d2a5e26fd658 MACROS.h --- a/MACROS.h Sun Apr 01 18:39:35 2018 +0000 +++ b/MACROS.h Sun May 05 14:57:11 2019 +0000 @@ -30,6 +30,7 @@ #include "MODSERIAL_KSDK.h" #include "MODSERIAL_NUCLEO_F401RE.h" #include "MODSERIAL_PAC_F401RB.h" +#include "MODSERIAL_NUCLEO_F103RB.h" #include "MODSERIAL_NUCLEO_F746ZG.h" #define MODSERIAL_TX_BUFFER_EMPTY (buffer_count[TxIrq]==0)