summaryrefslogtreecommitdiffstats
path: root/c/src
diff options
context:
space:
mode:
authorTill Straumann <strauman@slac.stanford.edu>2008-11-03 20:56:02 +0000
committerTill Straumann <strauman@slac.stanford.edu>2008-11-03 20:56:02 +0000
commit160e8fb59a66dba0553462577785f3bb944a7bdd (patch)
treeade055b496363e3e40f421412236d2692d8e8e5c /c/src
parent2008-11-03 Till Straumann <strauman@slac.stanford.edu> (diff)
downloadrtems-160e8fb59a66dba0553462577785f3bb944a7bdd.tar.bz2
2008-11-03 Till Straumann <strauman@slac.stanford.edu>
PR 1332: call BSP_uart_termios_set()/BSP_uart_intr_ctrl() only from 'firstOpen' and only if this is a serial console.
Diffstat (limited to 'c/src')
-rw-r--r--c/src/lib/libbsp/i386/pc386/console/console.c25
1 files changed, 16 insertions, 9 deletions
diff --git a/c/src/lib/libbsp/i386/pc386/console/console.c b/c/src/lib/libbsp/i386/pc386/console/console.c
index b972047a2c..126b0cb50b 100644
--- a/c/src/lib/libbsp/i386/pc386/console/console.c
+++ b/c/src/lib/libbsp/i386/pc386/console/console.c
@@ -273,6 +273,20 @@ static int console_last_close(int major, int minor, void *arg)
return 0;
}
+static int ser_console_first_open(int major, int minor, void *arg)
+{
+ /*
+ * Pass data area info down to driver
+ */
+ BSP_uart_termios_set(BSPConsolePort,
+ ((rtems_libio_open_close_args_t *)arg)->iop->data1);
+
+ /* Enable interrupts on channel */
+ BSP_uart_intr_ctrl(BSPConsolePort, BSP_UART_INTR_CTRL_TERMIOS);
+
+ return 0;
+}
+
/*-------------------------------------------------------------------------+
| Console device driver OPEN entry point
+--------------------------------------------------------------------------*/
@@ -320,6 +334,8 @@ console_open(rtems_device_major_number major,
cb.write = BSP_uart_termios_write_com2;
}
+ cb.firstOpen = ser_console_first_open;
+
status = rtems_termios_open (major, minor, arg, &cb);
if(status != RTEMS_SUCCESSFUL)
@@ -328,15 +344,6 @@ console_open(rtems_device_major_number major,
return status;
}
- /*
- * Pass data area info down to driver
- */
- BSP_uart_termios_set(BSPConsolePort,
- ((rtems_libio_open_close_args_t *)arg)->iop->data1);
-
- /* Enable interrupts on channel */
- BSP_uart_intr_ctrl(BSPConsolePort, BSP_UART_INTR_CTRL_TERMIOS);
-
return RTEMS_SUCCESSFUL;
}