RTEMS 6.1-rc6
|
The SS555 port was sponsored by Defence Research and Development Canada - Suffield, and is Copyright (C) 2004, Real-Time Systems Inc.
Please send any comments, improvements, or bug reports to:
David Querbach querb.nosp@m.ach@.nosp@m.realt.nosp@m.ime..nosp@m.bc.ca
The ss555 port uses the Intec SS555's external RAM in two different ways, depending on whether or not it is built for debugging by giving the VARIANT=DEBUG switch to make:
This BSP includes an termios-capable asynchronous serial line driver that supports SCI1 and SCI2. The RTEMS console is selected at configuration time with the CONSOLE_MINOR variable (see .../ss555/configure.ac). We default to SCI2 for the console, since SCI1 has some extra features which may be desired for application use.
The BSP console supports three different modes of operation:
The mode of operation of the serial driver is determined at configure time in part by the value of the UARTS_IO_MODE variable (see .../ss555/configure.ac).
0 - polled I/O. 1 - interrupt-driven I/O.
Also, set the value of UARTS_USE_TERMIOS to select whether termios should be used to perform buffering and input/output processing. Without termios support, input processing is limited to the substitution of LF for a received CR, and output processing is limited to the transmission of a CR following the transmission of a LF. The choices for UARTS_USE_TERMIOS are:
0 - do not use termios 1 - use termios
In most real-time applications, the driver should be configured to use termios and interrupt-driven I/O. Special requirements may dictate otherwise.
Polled I/O must be used when running the timing tests. It must also be used to run some other tests and some samples, such as the cdtest. Some tests change the interrupt mask and will hang interrupt-driven I/O indefinitely. Others, such as cdtest, perform console output from the static constructors before the console is opened, causing the test to hang. Still other tests produce output that is supposed to be in some specific order. For these tests, termios should not be used, as termios buffers output and the transmission of the buffers occur at somewhat unpredictable times.
The real solution is to fix the tests so that they work with interrupt-driven I/O and termios.
The implementation of printk() in RTEMS is mostly independent of most system services. The printk() function can therefore be used to print messages to a debug console, particularly when debugging startup code or device drivers, i.e. code that runs before the console driver is opened or that runs with interrupts disabled.
Support is provided to send printk output to either port. Specify the desired port at configure time by setting the value of PRINTK_MINOR to one of SCI1_MINOR or SCI2_MINOR.
printk() always uses polled I/O, and never uses termios.
If the printk() port is opened by RTEMS, then UARTS_IO_MODE must be set for polled I/O, otherwise the I/O functions will be in conflict. Using printk() before the port is initialized is, of course, not possible. This initialization occurs in console_initialize(), which is called by rtems_initialize_executive_early().
The MPC555 watchdog timer can be enabled at configuration time by defining the WATCHDOG_TIMEOUT variable. This variable sets the watchdog timeout period in steps of
2048 2048 --------- = --------- = 51.2 usec Fsystem 40 MHz
or about 1/20 msec. When WATCHDOG_TIMEOUT is left undefined, the watchdog timer is disabled.
Most code came from the mbx8xx port, except for the floating-point handling which came from the mpc8260ads.
The port was developed on an x86 box running Debian 3.0. The toolchain was built from the sources at rtems.org, except for the autotools which came from the Debian distribution.
Single processor tests:
All tests passed, except that:
Multi-processor tests:
Not applicable.
Library tests: All tests passed. Note that the termios test only works if the system is rebuilt with termios enabled.
Posix tests: All tests passed, except that:
Timing tests: Due to memory limitations, many of the tests will not run unless you set OPERATION_COUNT=20 at configuration time.
To run tm27 (the interrupt latency timer test), short CN5-48 to CN5-50 on the SS555 board.
All tests run cleanly, except for tm26, which gives a "PANIC 12" after it exits. This doesn't seem to cause a problem otherwise.
See the times file for the results of the timing tests.
Network tests:
Not applicable.
Sample programs: These run correctly, except that:
Various non-BSP-dependent support routines.
timer - Support for the RTEMS timer tick, using the Programmable Interval Timer (PIT).
console-generic - Console support via the on-chip dual SCI port in the QSMCM module.
exception - Installation and deinstallation of exception handlers, by manipulation of exception vector table.
irq - Exception handler for all external and decrementer interrupts. Generalized interrupt handler which calls specific handlers via entries in the interrupt connection table. Interrupt connection table maintenance routines. USIU and UIMB interrupt masking and level control.
timer - Support for RTEMS timer tests, using the PowerPC timebase (TB) registers.
vectors - Compressed MPC5XX exception vector table, exception handler prologues, default exception handler. Code to initialize table with default handlers.