summaryrefslogtreecommitdiff
path: root/src/arch
diff options
context:
space:
mode:
Diffstat (limited to 'src/arch')
-rw-r--r--src/arch/msp430fr5969lp/Kconfig7
-rw-r--r--src/arch/msp430fr5969lp/Makefile.inc4
-rw-r--r--src/arch/msp430fr5969lp/driver/stdin1.cc40
3 files changed, 51 insertions, 0 deletions
diff --git a/src/arch/msp430fr5969lp/Kconfig b/src/arch/msp430fr5969lp/Kconfig
index 0e7052d..7eba522 100644
--- a/src/arch/msp430fr5969lp/Kconfig
+++ b/src/arch/msp430fr5969lp/Kconfig
@@ -39,6 +39,13 @@ help
RX: P2.1 (eUSCI_A0 / UCA0RXD)
select meta_driver_stdin
+config arch_msp430fr5969lp_driver_stdin1
+bool "UART Input on eUSCI_A1 / P2.6"
+help
+ RX: P2.6 (eUSCI_A1 / UCA1RXD)
+depends on arch_msp430fr5969lp_driver_stdout1
+select meta_driver_stdin1
+
config arch_msp430fr5969lp_driver_timer
bool "Timer with Interrupts"
select meta_driver_timer
diff --git a/src/arch/msp430fr5969lp/Makefile.inc b/src/arch/msp430fr5969lp/Makefile.inc
index 0412516..6731a37 100644
--- a/src/arch/msp430fr5969lp/Makefile.inc
+++ b/src/arch/msp430fr5969lp/Makefile.inc
@@ -87,6 +87,10 @@ ifdef CONFIG_arch_msp430fr5969lp_driver_stdin
CXX_TARGETS += src/arch/msp430fr5969lp/driver/stdin.cc
endif
+ifdef CONFIG_arch_msp430fr5969lp_driver_stdin1
+ CXX_TARGETS += src/arch/msp430fr5969lp/driver/stdin1.cc
+endif
+
ifdef CONFIG_arch_msp430fr5969lp_driver_i2c
CXX_TARGETS += src/arch/msp430fr5969lp/driver/i2c.cc
COMMON_FLAGS += -DDRIVER_I2C
diff --git a/src/arch/msp430fr5969lp/driver/stdin1.cc b/src/arch/msp430fr5969lp/driver/stdin1.cc
new file mode 100644
index 0000000..efb7f90
--- /dev/null
+++ b/src/arch/msp430fr5969lp/driver/stdin1.cc
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2020 Birte Kristina Friesel
+ *
+ * SPDX-License-Identifier: BSD-2-Clause
+ */
+#include "driver/stdin1.h"
+#include <msp430.h>
+
+void StandardInput1::setup()
+{
+ UCA1CTLW0 |= UCSWRST;
+ P2SEL0 &= ~BIT6;
+ P2SEL1 |= BIT6;
+ UCA1CTLW0 &= ~UCSWRST;
+ UCA1IE |= UCRXIE;
+}
+
+bool StandardInput1::hasKey()
+{
+ if (write_pos != read_pos) {
+ return true;
+ }
+ return false;
+}
+
+char StandardInput1::getKey()
+{
+ char ret = buffer[read_pos++];
+ read_pos %= bufsize;
+ return ret;
+}
+
+StandardInput1 kin1;
+
+__attribute__((interrupt(USCI_A1_VECTOR))) __attribute__((wakeup)) void handle_stdin1()
+{
+ if (UCA1IFG & UCRXIFG) {
+ kin1.addKey(UCA1RXBUF);
+ }
+}