MODSERIAL with support for more devices

Fork of MODSERIAL by Erik -

Files at this revision

API Documentation at this revision

Comitter:
fahadmirza
Date:
Wed Jul 11 08:17:03 2018 +0000
Parent:
45:da0788f0bd77
Commit message:
Added support for NUCLEO_L053R8

Changed in this revision

Device/MODSERIAL_NUCLEO_L053R8.cpp Show annotated file Show diff for this revision Revisions of this file
Device/MODSERIAL_NUCLEO_L053R8.h Show annotated file Show diff for this revision Revisions of this file
MACROS.h Show annotated file Show diff for this revision Revisions of this file
diff -r da0788f0bd77 -r 6571cd7f896e Device/MODSERIAL_NUCLEO_L053R8.cpp
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Device/MODSERIAL_NUCLEO_L053R8.cpp	Wed Jul 11 08:17:03 2018 +0000
@@ -0,0 +1,24 @@
+#ifdef TARGET_NUCLEO_L053R8
+#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 = LPUART1; _IRQ = LPUART1_IRQn; break;
+        default: _base = NULL; _IRQ = (IRQn_Type)NULL; break;
+    }
+}
+
+void MODSERIAL::initDevice(void) {};
+
+bool MODSERIAL::txIsBusy( void )
+{
+    return ( (((USART_TypeDef*)_base)->ISR & ( 1UL << 6 )) == 0 ) ? true : false;
+}
+
+#endif
diff -r da0788f0bd77 -r 6571cd7f896e Device/MODSERIAL_NUCLEO_L053R8.h
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Device/MODSERIAL_NUCLEO_L053R8.h	Wed Jul 11 08:17:03 2018 +0000
@@ -0,0 +1,20 @@
+#if defined(TARGET_NUCLEO_L053R8)
+
+#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)->RDR
+#define MODSERIAL_WRITE_REG ((USART_TypeDef*)_base)->TDR
+#define MODSERIAL_READABLE ((((USART_TypeDef*)_base)->ISR & USART_ISR_RXNE) != 0)
+#define MODSERIAL_WRITABLE ((((USART_TypeDef*)_base)->ISR & USART_ISR_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 6571cd7f896e MACROS.h
--- a/MACROS.h	Sun Apr 01 18:39:35 2018 +0000
+++ b/MACROS.h	Wed Jul 11 08:17:03 2018 +0000
@@ -31,6 +31,7 @@
 #include "MODSERIAL_NUCLEO_F401RE.h"
 #include "MODSERIAL_PAC_F401RB.h"
 #include "MODSERIAL_NUCLEO_F746ZG.h"
+#include "MODSERIAL_NUCLEO_L053R8.h"
 
 #define MODSERIAL_TX_BUFFER_EMPTY (buffer_count[TxIrq]==0)
 #define MODSERIAL_RX_BUFFER_EMPTY (buffer_count[RxIrq]==0)