summaryrefslogtreecommitdiffstats
path: root/c/src/lib/libbsp/powerpc/ss555/README
blob: 54d0bfa85a0fd7c6929afeb3dfcb1773a3b9156e (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
This is a README file for the Intec SS555 of RTEMS 4.6.0

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
querbach@realtime.bc.ca


Summary
-------

BSP NAME:           ss555
BOARD:              Intec Automation Inc. SS555
BUS:                None 
CPU FAMILY:         PowerPC
CPU:                PowerPC MPC555
COPROCESSORS:       Built-in Motorola TPU
MODE:               32 bit mode

DEBUG MONITOR:      None

PERIPHERALS
===========
TIMERS:             PIT / Timebase
  RESOLUTION:       1 microsecond (4 MHz crystal / 4)
SERIAL PORTS:       2 SCI
REAL-TIME CLOCK:    On-chip.
DMA:                None.
VIDEO:              None.
SCSI:               None.
NETWORKING:         None.
		   

DRIVER INFORMATION
==================
CLOCK DRIVER:       yes
CONSOLE DRIVER:     yes
SHMSUPP:            N/A
TIMER DRIVER:       yes
NETWORK DRIVER:	    no

NOTES
=====
On-chip resources:
	SCI1		serial port
	SCI2		serial port (console)
	PIT		clock
	TB		timing test support
	DEC
	SWT		watchdog timer -- enable in startup/iss555.c
	*CS0		external 512k 2-1-1-1 Burst SRAM
	*CS1
	*CS2
	*CS3		CPLD
	IRQ0
	IRQ1
	IRQ2		
	IRQ3		
	IRQ4		
	IRQ5	
	IRQ6
	IRQ7
	IRQ_LVL0	
	IRQ_LVL1
	IRQ_LVL2
	IRQ_LVL3
	IRQ_LVL4
	IRQ_LVL5	SCI
	IRQ_LVL6	PIT
	IRQ_LVL7
	

Board description
-----------------
Clock rate:     40 MHz development/embeddable board
Bus width:      32-bit on-board RAM, 16-bit off-board I/O
FLASH:	        512k on-chip
RAM:            512k 2-1-1-1 burst SRAM


Installation
------------

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:

	make VARIANT=DEBUG all

1.  In the debugging case, the linker script concanttenates the .text,
.data, and .bss sections starting at location zero, so they all can be
loaded into the external RAM for debugging.  We assume that the debugger
disables the internal Flash ROM and enables the external RAM before loading
the code into the external RAM.

2.  In the normal (non-debugging) case, the linker script still places the
.text section near zero, but places the start of the .data and .bss sections
at the start location of the MPC555's internal RAM.  The system startup code
then configures the external RAM just after the internal RAM in memory,
forming one large block from the two RAM devices.


Console driver
---------------

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:

  1. polled I/O done with termios support,
  2. polled I/O done without termios support,
  3. interrupt-driven I/O with termios support.
     
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.


printk() and debug output
-----------------------

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().


Watchdog Timer
--------------

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.


Miscellaneous
-------------

Most code came from the mbx8xx port, except for the floating-point handling
which came from the mpc8260ads.


Host System
-----------

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.


Test Configuration
------------------

Board:                Intec SS555 v1.1
CPU:                  Motorola MPC555LFMZP40, mask 1K83H
Clock Speed:          Crystal 4.0 MHz, CPU 40.0 MHz
RAM:                  512K bytes of 2-1-1-1 Burst SRAM
Times Reported in:    Microseconds
Timer Source:         Timebase clock
GCC Flags:            -O4 -fno-keep-inline-functions -mcpu=(821/860) 
Console:              Operates in polled mode on SMC2. No I/O through EPPC-Bug.    


Test Results
------------

Single processor tests:  
  All tests passed, except that:
    - sp09 aborts due to memory shortage
    - sp20 needs to be run with output buffering enabled (see
      buffer_test_io.h)

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:
    - the message queue test failed with "errno (91 - File or path name too
      long)"

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:
    - The "minimum" sample is not designed to run properly on any system.
    - The loopback, fileio, unilimited, and pppd tests fail due to memory
      limitations.
    - The paranoia program dies on a floating-point assist exception.

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.