summaryrefslogtreecommitdiffstats
path: root/c
diff options
context:
space:
mode:
authorTill Straumann <strauman@slac.stanford.edu>2008-11-03 21:10:25 +0000
committerTill Straumann <strauman@slac.stanford.edu>2008-11-03 21:10:25 +0000
commit1f8ac4aa090dbad6ae6986632c7a06d647185f6a (patch)
treea22742de62f767617550cb892bebf0de4f73e78d /c
parent2008-11-03 Till Straumann <strauman@slac.stanford.edu> (diff)
downloadrtems-1f8ac4aa090dbad6ae6986632c7a06d647185f6a.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')
-rw-r--r--c/src/lib/libbsp/powerpc/ChangeLog5
-rw-r--r--c/src/lib/libbsp/powerpc/shared/console/console.c17
2 files changed, 14 insertions, 8 deletions
diff --git a/c/src/lib/libbsp/powerpc/ChangeLog b/c/src/lib/libbsp/powerpc/ChangeLog
index aa5f39d570..854342719b 100644
--- a/c/src/lib/libbsp/powerpc/ChangeLog
+++ b/c/src/lib/libbsp/powerpc/ChangeLog
@@ -1,5 +1,10 @@
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.
+
+2008-11-03 Till Straumann <strauman@slac.stanford.edu>
+
* shared/startup/pretaskinghook.c, shared/startup/sbrk.c:
Fixed PR#1335.
diff --git a/c/src/lib/libbsp/powerpc/shared/console/console.c b/c/src/lib/libbsp/powerpc/shared/console/console.c
index ab05e9e98a..544feaef70 100644
--- a/c/src/lib/libbsp/powerpc/shared/console/console.c
+++ b/c/src/lib/libbsp/powerpc/shared/console/console.c
@@ -167,6 +167,15 @@ static int console_first_open(int major, int minor, void *arg)
ttyS[minor].name);
rtems_fatal_error_occurred(status);
}
+
+ /*
+ * Pass data area info down to driver
+ */
+ BSP_uart_termios_set(minor, ((rtems_libio_open_close_args_t *)arg)->iop->data1);
+
+ /* Enable interrupts on channel */
+ BSP_uart_intr_ctrl(minor, BSP_UART_INTR_CTRL_TERMIOS);
+
return 0;
}
@@ -222,14 +231,6 @@ rtems_device_driver console_open(
return status;
}
- /*
- * Pass data area info down to driver
- */
- BSP_uart_termios_set(minor,
- ((rtems_libio_open_close_args_t *)arg)->iop->data1);
- /* Enable interrupts on channel */
- BSP_uart_intr_ctrl(minor, BSP_UART_INTR_CTRL_TERMIOS);
-
return RTEMS_SUCCESSFUL;
}