[PATCH 2/6] termios: Add TERMIOS_IRQ_SERVER_DRIVEN

Sebastian Huber sebastian.huber at embedded-brains.de
Wed Dec 14 13:39:38 UTC 2016


From: Alexander Krutwig <alexander.krutwig at embedded-brains.de>

Add a new interrupt server driven Termios mode (TERMIOS_IRQ_DRIVEN).
This mode is identical to the interrupt driven mode except that a mutex
is used for device level locking. The intended use case for this mode
are device drivers that use the interrupt server, e.g. SPI or I2C
connected devices.

Update #2839.
---
 cpukit/libcsupport/include/rtems/termiostypes.h | 10 ++++++----
 cpukit/libcsupport/src/termios.c                |  3 ++-
 2 files changed, 8 insertions(+), 5 deletions(-)

diff --git a/cpukit/libcsupport/include/rtems/termiostypes.h b/cpukit/libcsupport/include/rtems/termiostypes.h
index 81d28c2..ffe172c 100644
--- a/cpukit/libcsupport/include/rtems/termiostypes.h
+++ b/cpukit/libcsupport/include/rtems/termiostypes.h
@@ -57,7 +57,8 @@ struct rtems_termios_rawbuf {
 typedef enum {
   TERMIOS_POLLED,
   TERMIOS_IRQ_DRIVEN,
-  TERMIOS_TASK_DRIVEN
+  TERMIOS_TASK_DRIVEN,
+  TERMIOS_IRQ_SERVER_DRIVEN
 } rtems_termios_device_mode;
 
 struct rtems_termios_tty;
@@ -74,7 +75,7 @@ typedef struct rtems_termios_device_context {
     /* Used for TERMIOS_POLLED and TERMIOS_IRQ_DRIVEN */
     rtems_interrupt_lock interrupt;
 
-    /* Used for TERMIOS_TASK_DRIVEN */
+    /* Used for TERMIOS_IRQ_SERVER_DRIVEN or TERMIOS_TASK_DRIVEN */
     rtems_id mutex;
   } lock;
 
@@ -161,8 +162,9 @@ typedef struct {
   /**
    * @brief Polled read.
    *
-   * In case mode is TERMIOS_IRQ_DRIVEN or TERMIOS_TASK_DRIVEN, then data is
-   * received via rtems_termios_enqueue_raw_characters().
+   * In case mode is TERMIOS_IRQ_DRIVEN, TERMIOS_IRQ_SERVER_DRIVEN or
+   * TERMIOS_TASK_DRIVEN, then data is received via
+   * rtems_termios_enqueue_raw_characters().
    *
    * @param[in] context The Termios device context.
    *
diff --git a/cpukit/libcsupport/src/termios.c b/cpukit/libcsupport/src/termios.c
index 3bc5bb8..d3757df 100644
--- a/cpukit/libcsupport/src/termios.c
+++ b/cpukit/libcsupport/src/termios.c
@@ -275,7 +275,8 @@ drainOutput (struct rtems_termios_tty *tty)
 static bool
 needDeviceMutex (rtems_termios_tty *tty)
 {
-  return tty->handler.mode == TERMIOS_TASK_DRIVEN;
+  return tty->handler.mode == TERMIOS_IRQ_SERVER_DRIVEN
+    || tty->handler.mode == TERMIOS_TASK_DRIVEN;
 }
 
 static void
-- 
1.8.4.5



More information about the devel mailing list