32 BIT MICROPROCESSOR

FEATURES

- Enhanced 32-bit CPU
  - 0 to 40 MHz processor clock
  - 32 MIPS at 40 MHz
  - fast integer/bit operations
- 16 Kbytes on-chip SRAM
  - 160 Mbytes/s maximum bandwidth
- Programmable memory interface
  - 4 separately configurable regions
  - 8/16/32-bits wide
  - support for mixed memory
  - 2 cycle external access
  - support for page mode DRAM
- Serial communications
  - 4 OS-Links
  - 5/10/20 Mbits/s Link0, 10/20 Mbits/s Link1-3
  - Event channel
- Vectored interrupt subsystem
  - Fully prioritized interrupts
  - 8 levels of preemption
  - 500 ns response time
- Power management
  - low power operation
  - power down mode
- Professional toolset support
  - ANSI C compiler and libraries
  - INQUEST advanced debugging tools
- Technology
  - 0 to 40 MHz processor clock
  - 0.5 micron process technology
  - 3 V operation (3 V outputs/bi-directionals, 5 V inputs)
- 208 pin PQFP package
- Test Access Port

APPLICATIONS

- Global positioning by satellite (GPS) receivers
- ISDN terminals
- ATM networks
- Set top terminals
- Industrial control
- Imaging systems
**Trap enables word**

This register contains the word which encodes the trap enable and global interrupt masks. This should be ANDed with the existing masks to allow the trap handler to disable various events while it runs. However, currently the trap enables word overwrites the existing enables.

With this implementation a trap must disable all other trap groups to ensure correct execution, this increases the difficulty of writing nested trap handlers.

**Analysing high priority processes**

If the machine is running a high priority process before being analysed and the device is wired to boot from link, not ROM, then the machine will resume execution of that high priority process as soon as it is released from analyse. The Wptr will also be set back to MemStart.

This will cause the machine to crash, there is no workaround.

**Disable external micro-interrupt requests**

There are four possible combinations of enable/disable for high and low priority micro-interrupts, however only three are supported. It is not recommended to disable high priority micro-interrupts with low priority interrupts enabled.

With this combination it is possible for high priority external events that are apparently disabled to be accepted as low priority transactions.

**Timer scheduler traps always run high priority handler**

When a scheduler trap is set, the priority of the scheduler event is stored in the scheduler trap priority field of the Status register. For Timer scheduler traps the priority is always recorded as high.

This results in the wrong trap handler being executed, which is fatal if there is no high priority scheduler trap installed.

**Incorrect order of boundary-scan chain**

Due to an error in the boundary-scan logic, EventWaiting effectively does not have a boundary-scan cell.

The consequence being that EXTEST will no longer function correctly for the EventWaiting pin. Revised boundary scan description language (BSDL) is available.

**Illegal configuration for strobos**

If any strobe is configured with edge times of: e1time = 0, e2time = (castime*2) - 1 phases, that strobe will behave erroneously when back to back accesses occur.

**Erroneous address during RAS time for 16/8 bit accesses**

An erroneous address may appear during the first cycle of RAS time whenever a multi-access transaction includes an excursion into a precharge state, for example, if a series of 8-bit accesses are interrupted by a refresh.

The solution is to program the ShiftAmount for all banks with the same value. Memory banks consisting of SRAM only will not be affected by the ShiftAmount value as it is not used unless RAS time is non zero anyway.

**Divide and remainder instruction errors**

The div (divide) and rem (remainder) instructions do not work correctly in some situations if the dividend is negative.

The compiler works around this by replacing each div and rem instruction with a code sequence which first checks the sign of the dividend and, if it is negative, flips the sign, performs the operation and then flips the sign of the result.

Where these instructions are used explicitly in other toolset software, e.g. libraries, the workarounds have been hard coded. Unlike compiler generated workarounds, it is not possible to disable such hard coded workarounds.
# Contents

1 Introduction ................................................................. 7

2 Architecture ................................................................. 8

3 Central Processing Unit ..................................................... 11
   3.1 Registers ..................................................................... 11
   3.2 Processes and concurrency ............................................ 12
   3.3 Priority ...................................................................... 14
   3.4 Process communications ............................................. 14
   3.5 Timers ....................................................................... 15
   3.6 Traps and exceptions ................................................. 16
      3.6.1 Trap groups ....................................................... 16
      3.6.2 Events that can cause traps ................................... 18
      3.6.3 Trap handlers ..................................................... 19
      3.6.4 Trap instructions .................................................. 20
      3.6.5 Restrictions on trap handlers ................................. 20

4 Interrupt controller .......................................................... 21
   4.1 Interrupt vector table .................................................. 22
   4.2 Interrupt handlers ...................................................... 22
   4.3 Interrupt latency ....................................................... 23
   4.4 Pre-emption and interrupt priority ................................ 23
   4.5 Restrictions on interrupt handlers ................................. 24
   4.6 Interrupt configuration registers .................................. 24
      4.6.1 HandlerWptr0-7 registers ................................. 24
      4.6.2 TriggerMode0-7 registers ................................. 24
      4.6.3 Mask register ..................................................... 25
      4.6.4 Pending register .................................................. 26
      4.6.5 Exec register ...................................................... 27

5 Instruction set ................................................................. 28
   5.1 Instruction cycles ....................................................... 28
   5.2 Instruction characteristics .......................................... 29
   5.3 Instruction set tables .................................................. 30

6 Memory map ................................................................. 38
   6.1 System memory use ................................................... 38
      6.1.1 Subsystem channels memory ............................ 38
      6.1.2 Trap handlers memory ...................................... 38
   6.2 Boot ROM .............................................................. 39
   6.3 Internal peripheral space ............................................. 39
Contents

<table>
<thead>
<tr>
<th>Section</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>12.2 OS-Link speed</td>
<td>73</td>
</tr>
<tr>
<td>12.3 OS-Link connections</td>
<td>74</td>
</tr>
<tr>
<td>12.4 Event</td>
<td>75</td>
</tr>
<tr>
<td>13 Software development</td>
<td>76</td>
</tr>
<tr>
<td>13.1 ST20 toolset</td>
<td>76</td>
</tr>
<tr>
<td>13.1.1 Debugging and profiling software</td>
<td>76</td>
</tr>
<tr>
<td>14 Configuration register addresses</td>
<td>77</td>
</tr>
<tr>
<td>15 Electrical specifications</td>
<td>79</td>
</tr>
<tr>
<td>15.1 Absolute maximum ratings</td>
<td>79</td>
</tr>
<tr>
<td>15.2 Operating conditions</td>
<td>79</td>
</tr>
<tr>
<td>15.3 DC specifications</td>
<td>80</td>
</tr>
<tr>
<td>16 Timing specifications</td>
<td>81</td>
</tr>
<tr>
<td>16.1 EMI timings</td>
<td>81</td>
</tr>
<tr>
<td>16.2 Link timings</td>
<td>85</td>
</tr>
<tr>
<td>16.3 Reset and Analyse timings</td>
<td>86</td>
</tr>
<tr>
<td>16.4 Event timings</td>
<td>87</td>
</tr>
<tr>
<td>16.5 Clock timings</td>
<td>88</td>
</tr>
<tr>
<td>16.5.1 ClockIn and LinkClockIn timings</td>
<td>88</td>
</tr>
<tr>
<td>16.5.2 ProcClkOut timings</td>
<td>89</td>
</tr>
<tr>
<td>16.6 TAP timings</td>
<td>90</td>
</tr>
<tr>
<td>17 Pin designations</td>
<td>91</td>
</tr>
<tr>
<td>18 Package specifications</td>
<td>94</td>
</tr>
<tr>
<td>18.1 ST20450 package pinout</td>
<td>94</td>
</tr>
<tr>
<td>18.2 ST20450 208 pin PQFP package dimensions</td>
<td>95</td>
</tr>
<tr>
<td>18.3 ST20450 208 pin PQFP package thermal data</td>
<td>97</td>
</tr>
<tr>
<td>19 Ordering information</td>
<td>98</td>
</tr>
<tr>
<td>A Boundary scan description language (BSDL) file</td>
<td>99</td>
</tr>
</tbody>
</table>
1 Introduction

The ST20 micro core family has been developed by SGS-THOMSON Microelectronics to provide the tools and building blocks to enable the development of highly integrated, application specific 32-bit micros at the lowest cost and fastest time to market. The ST20 macrocell library includes the ST20 family of 32-bit micro cores, embedded memory, standard peripherals, I/O, controllers and customer specified ASICs.

Using ST20 macrocell technology SGS-THOMSON's world-wide technology partners in markets such as set top boxes, digital cellular handsets, hard disk drives and laser printers, are able to specify optimized 32-bit microcontrollers for their applications. Using ST20 technology SGS-THOMSON is able to develop these low cost application specific micros, from paper specification to silicon in less than six months.

The ST20 family of 32-bit micro cores has been designed for applications ranging from deeply embedded low cost portable systems to high performance applications requiring DSP type performance. At the heart of each ST20 core is a highly efficient 32-bit RISC processor, running at frequencies up to 40 MHz on 0.5 micron technology, and achieving up to 32 MIPS performance. The ST20 RISC CPU has a very efficient instruction set and achieves ultra high code density minimizing system ROM requirements and reducing system cost. The first member of the core family, the ST20C4, is a high performance core incorporating the ST20 RISC CPU, the ST20 in-core microkernel and the ST20 high performance arithmetic accelerator. The arithmetic accelerator contains a dedicated hardware multiplier providing two cycle 32-bit multiply and a hardware barrel shifter providing single cycle bit shift. The ST20 in-core microkernel is the highest performance micro-kernel of any 32-bit core, directly supporting multi tasking, I/O, DMA, interrupts, trap handling and timers. It combines the flexibility of a software RTOS with the performance of a microcoded scheduler, achieving context switch and interrupt response times of less than 500ns. It also provides a platform for the efficient porting of industry standard run-time kernels and operating systems (RTOS), making the ST20 ideal for interrupt driven real-time applications that require high data throughput, combined with high performance data processing.

The first product developed using the ST20 macrocell library is the ST20450, incorporating the ST20C4 core, 16 Kbytes of on-chip memory for fast access to local code, a vectored interrupt controller, serial I/O links, and a multi-bank external memory controller supporting SRAM, DRAM, ROM and memory mapped peripherals. The ST20450 has been designed for a class of applications that require high CPU performance and real time execution coupled with low power operation, including ISDN terminals, ATM networks and industrial control systems. Furthermore, the ST20450 acts as a reference platform for all future ST20 application specific designs.

To support the fast turnaround development of ST20 application specific micros an integrated software and hardware development environment has been developed to enable efficient, high performance code to be written and debugged, and system hardware to be simulated, developed and tested. This includes a complete professional ANSI-C software toolset, and the INQUEST window based debugging tools supporting PC and UNIX hosts.
2 Architecture

Figure 2.1 shows the subsystem modules that comprise the ST20450. These modules are outlined below and more detailed information is given in the following chapters of this datasheet.

The modules are connected via the ST20 Bus. The ST20 Bus is based on two buses, the memory bus and the command bus. The memory bus is used to access all memory in an ST20450 system, both internal and external. It supports single cycle pipelined accesses with two cycle latency. The
command bus is used for interfacing to standard peripherals and sending control information between ST20450 subsystems. The command bus supports point to point message passing using channel communications, and supports the PI-Bus protocol whereby a subsystem can directly access a memory mapped peripheral.

**CPU**

The Central Processing Unit (CPU) on the ST20450 is the ST20 32-bit processor core. It contains instruction processing logic, instruction and data pointers, and an operand register. It directly accesses the high speed on-chip memory, which can store data or programs. Where larger amounts of memory are required, the processor can access memory via the External Memory Interface (EMI).

**Memory subsystem**

The ST20450 on-chip memory system provides 200 Mbytes/s internal data bandwidth, supporting pipelined 2-cycle internal memory access at 25 ns cycle times. The ST20450 memory system consists of SRAM and an external memory interface (EMI). The first ST20450 product has 16 Kbytes of on-chip SRAM.

ST20450 derivative products will have a minimum of 4 Kbytes of on-chip SRAM. The advantage of this is the ability to store time critical code on chip, for instance interrupt routines, software kernels or device drivers, and even frequently used data. Furthermore small systems could place all code and data on-chip, increasing performance and reducing system cost.

The ST20450 External Memory Interface (EMI) controls the movement of data between the ST20450 and off-chip memory. It is designed to support memory subsystems with minimal (often zero) external support logic and is programmable to support a wide range of memory types.

The ST20450 EMI can access a 4 Gbyte physical address space, and provides sustained transfer rates of up to 100 Mbytes/s for SRAM, up to 89 Mbytes/s using page-mode DRAM.

**Communications subsystem**

The ST20450 has an OS-Link based serial communications subsystem. OS-Links use an asynchronous bit-serial (byte-stream) protocol, each bit received is sampled five times, hence the term *oversampled links* (OS-Links). Each OS-Link provides a pair of channels, one input and one output channel.

There are four OS-Links (Link0-3) on the ST20450 which act as individual DMA engines independent of the CPU. The OS-Links have programmable unidirectional data rates of 10 Mbits/s or 20 Mbits/s, giving a bi-directional bandwidth of 3 Mbytes/s. Link0 can also be run at 5 Mbits/s.

The links are used for:
- interfacing to external peripherals
- bootstrapping
- debugging

**Interrupt subsystem**

The ST20450 interrupt subsystem supports eight prioritized interrupts. This allows nested pre-emptive interrupts for real-time system design.

**System services module**

The ST20450 system services module includes:
- reset, initialization and error port.
• phase locked loop (PLL) - accepts 5 MHz input and generates all the internal high frequency clocks needed for the CPU and the OS-Links.
• test access port.
3 Central Processing Unit

The Central Processing Unit (CPU) is the ST20 32-bit processor core. It contains instruction processing logic, instruction and data pointers, and an operand register. It can directly access the high speed on-chip memory, which can store data or programs. Where larger amounts of memory are required, the processor can access memory via the External Memory Interface (EMI).

The processor provides high performance:
- Fast integer multiply - 3 cycle multiply
- Fast bit shift - single cycle barrel shifter
- Byte and part-word handling
- Scheduling and interrupt support
- 64-bit integer arithmetic support

The scheduler provides a single level of pre-emption. In addition, multi-level pre-emption is provided by the interrupt subsystem, see Chapter 4 for details. Additionally, there is a per-priority trap handler to improve the support for arithmetic errors and illegal instructions, refer to section 3.6.

3.1 Registers

The CPU contains six registers which are used in the execution of a sequential integer process. The six registers are:
- The workspace pointer (Wptr) which points to an area of store where local data is kept.
- The instruction pointer (IptrReg) which points to the next instruction to be executed.
- The status register (StatusReg).
- The Areg, Breg and Creg registers which form an evaluation stack.

The Areg, Breg and Creg registers are the sources and destinations for most arithmetic and logical operations. Loading a value into the stack pushes Breg into Creg, and Areg into Breg, before loading Areg. Storing a value from Areg, pops Breg into Areg and Creg into Breg. Creg is left undefined.

![Registers used in sequential integer processes](image)
Expressions are evaluated on the evaluation stack, and instructions refer to the stack implicitly. For example, the add instruction adds the top two values in the stack and places the result on the top of the stack. The use of a stack removes the need for instructions to explicitly specify the location of their operands. No hardware mechanism is provided to detect that more than three values have been loaded onto the stack; it is easy for the compiler to ensure that this never happens.

Note that a location in memory can be accessed relative to the workspace pointer, enabling the workspace to be of any size.

The use of shadow registers provides fast, simple and clean context switching.

3.2 Processes and concurrency

The following section describes ‘default’ behavior of the CPU and it should be noted that the user can alter this behavior, for example, by disabling timeslicing, installing a user scheduler, etc.

A process starts, performs a number of actions, and then either stops without completing or terminates complete. Typically, a process is a sequence of instructions. The CPU can run several processes in parallel (concurrently). Processes may be assigned either high or low priority, and there may be any number of each.

The processor has a microcoded scheduler which enables any number of concurrent processes to be executed together, sharing the processor time. This removes the need for a software kernel, although kernels can still be written if desired.

At any time, a process may be

- **active** - being executed
- - interrupted by a higher priority process
- - on a list waiting to be executed

- **inactive** - waiting to input
- - waiting to output
- - waiting until a specified time

The scheduler operates in such a way that inactive processes do not consume any processor time. Each active high priority process executes until it becomes inactive. The scheduler allocates a portion of the processor’s time to each active low priority process in turn (see Section 3.3 on page 14). Active processes waiting to be executed are held in two linked lists of process workspaces, one of high priority processes and one of low priority processes. Each list is implemented using two registers, one of which points to the first process in the list, the other to the last. In the linked process list shown in Figure 3.2, process S is executing and R, Q and P are active, awaiting execution. Only the low priority process queue registers are shown; the high priority process ones behave in a similar manner.
Each process runs until it has completed its action or is descheduled. In order for several processes to operate in parallel, a low priority process is only permitted to execute for a maximum of two timeslice periods. After this, the machine deschedules the current process at the next timeslicing point, adds it to the end of the low priority scheduling list and instead executes the next active process. The timeslice period is 1ms.

There are only certain instructions at which a process may be descheduled. These are known as descheduling points. A process may only be timesliced at certain descheduling points. These are known as timeslicing points and are defined in such a way that the operand stack is always empty. This removes the need for saving the operand stack when timeslicing. As a result, an expression evaluation can be guaranteed to execute without the process being timesliced part way through.

Whenever a process is unable to proceed, its instruction pointer is saved in the process workspace and the next process taken from the list.

The processor core provides a number of special instructions to support the process model, including startp (start process) and endp (end process). When a main process executes a parallel construct, startp is used to create the necessary additional concurrent processes. A startp instruction creates a new process by adding a new workspace to the end of the scheduling list, enabling the new concurrent process to be executed together with the ones already being executed. When a process is made active it is always added to the end of the list, and thus cannot pre-empt processes already on the same list.

The correct termination of a parallel construct is assured by use of the endp instruction. This uses a data structure that includes a counter of the parallel construct components which have still to

<table>
<thead>
<tr>
<th>Function</th>
<th>High priority</th>
<th>Low priority</th>
</tr>
</thead>
<tbody>
<tr>
<td>Pointer to front of active process list</td>
<td>FptrReg0</td>
<td>FptrReg1</td>
</tr>
<tr>
<td>Pointer to back of active process list</td>
<td>BptrReg0</td>
<td>BptrReg1</td>
</tr>
</tbody>
</table>
terminate. The counter is initialized to the number of components before the processes are started. Each component ends with an endp instruction which decrements and tests the counter. For all but the last component, the counter is non-zero and the component is descheduled. For the last component, the counter is zero and the main process continues.

### 3.3 Priority

The following section describes ‘default’ behavior of the CPU and it should be noted that the user can alter this behavior, for example, by disabling timeslicing and priority interrupts.

The processor can execute processes at one of two priority levels, one level for urgent (high priority) processes, one for less urgent (low priority) processes. A high priority process will always execute in preference to a low priority process if both are able to do so.

High priority processes are expected to execute for a short time. If one or more high priority processes are active, then the first on the queue is selected and executes until it has to wait for a communication, a timer input, or until it completes processing.

If no process at high priority is active, but one or more processes at low priority are active, then one is selected. Low priority processes are periodically timesliced to provide an even distribution of processor time between computationally intensive tasks.

If there are \( n \) low priority processes, then the maximum latency from the time at which a low priority process becomes active to the time when it starts processing is the order of \( 2n \) timeslice periods. It is then able to execute for between one and two timeslice periods, less any time taken by high priority processes. This assumes that no process monopolizes the CPU’s time; i.e. it has frequent timeslicing points.

The specific condition for a high priority process to start execution is that the CPU is idle or running at low priority and the high priority queue is non-empty.

If a high priority process becomes able to run whilst a low priority process is executing, the low priority process is temporarily stopped and the high priority process is executed. The state of the low priority process is saved into ‘shadow’ registers and the high priority process is executed. When no further high priority processes are able to run, the state of the interrupted low priority process is re-loaded from the shadow registers and the interrupted low priority process continues executing. Instructions are provided on the processor core to allow a high priority process to store the shadow registers to memory and to load them from memory. Instructions are also provided to allow a process to exchange an alternative process queue for either priority process queue (see Table 5.21 on page 36). These instructions allow extensions to be made to the scheduler for custom runtime kernels.

A low priority process may be interrupted after it has completed execution of any instruction. In addition, to minimize the time taken for an interrupting high priority process to start executing, the potentially time consuming instructions are interruptible. Also some instructions are abortable and are restarted when the process next becomes active (refer to the Instruction Set chapter).

### 3.4 Process communications

Communication between processes takes place over channels, and is implemented in hardware. Communication is point-to-point, synchronized and unbuffered. As a result, a channel needs no process queue, no message queue and no message buffer.
A channel between two processes executing on the same CPU is implemented by a single word in memory; a channel between processes executing on different processors is implemented by point-to-point links. The processor provides a number of operations to support message passing, the most important being `in` (input message) and `out` (output message).

The `in` and `out` instructions use the address of the channel to determine whether the channel is internal or external. This means that the same instruction sequence can be used for both hard and soft channels, allowing a process to be written and compiled without knowledge of where its channels are implemented.

Communication takes place when both the inputting and outputting processes are ready. Consequently, the process which first becomes ready must wait until the second one is also ready. The inputting and outputting processes only become active when the communication has completed.

A process performs an input or output by loading the evaluation stack with, a pointer to a message, the address of a channel, and a count of the number of bytes to be transferred, and then executing an `in` or `out` instruction.

### 3.5 Timers

There are two 32-bit hardware timer clocks which ‘tick’ periodically. These are independent of any on-chip peripheral real time clock. The timers provide accurate process timing, allowing processes to deschedule themselves until a specific time.

One timer is accessible only to high priority processes and is incremented every microsecond, cycling completely in approximately 4295 seconds. The other is accessible only to low priority processes and is incremented every 64 microseconds, giving 15625 ticks in one second. It has a full period of approximately 76 hours. All times are approximate due to the clock rate.

<table>
<thead>
<tr>
<th>Register</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>ClockReg0</td>
<td>Current value of high priority (level 0) process clock</td>
</tr>
<tr>
<td>ClockReg1</td>
<td>Current value of low priority (level 1) process clock</td>
</tr>
<tr>
<td>TnextReg0</td>
<td>Indicates time of earliest event on high priority (level 0) timer queue</td>
</tr>
<tr>
<td>TnextReg1</td>
<td>Indicates time of earliest event on low priority (level 1) timer queue</td>
</tr>
<tr>
<td>TptrReg0</td>
<td>High priority timer queue</td>
</tr>
<tr>
<td>TptrReg1</td>
<td>Low priority timer queue</td>
</tr>
</tbody>
</table>

Table 3.2 Timer registers

The current value of the processor clock can be read by executing a `ldtimer` (load timer) instruction. A process can arrange to perform a `tin` (timer input), in which case it will become ready to execute after a specified time has been reached. The `tin` instruction requires a time to be specified. If this time is in the ‘past’ then the instruction has no effect. If the time is in the ‘future’ then the process is descheduled. When the specified time is reached the process becomes active. In addition, the `ldclock` (load clock), `stclock` (store clock) instructions allow total control over the clock value and the `clockenb` (clock enable), `clockdis` (clock disable) instructions allow each clock to be individually stopped and re-started.

Figure 3.3 shows two processes waiting on the timer queue, one waiting for time 21, the other for time 31.
Note, these timers stop counting when power-down mode (see Chapter 11) is invoked.

Figure 3.3 Timer registers

3.6 Traps and exceptions

A software error, such as arithmetic overflow or array bounds violation, can cause an error flag to be set in the CPU. The flag is directly connected to the ErrorOut pin. Both the flag and the pin can be ignored, or the CPU stopped. Stopping the CPU on an error means that the error cannot cause further corruption. As well as containing the error in this way it is possible to determine the state of the CPU and its memory at the time the error occurred. This is particularly useful for postmortem debugging where the debugger can be used to examine the state and history of the processor leading up to and causing the error condition.

In addition, if a trap handler process is installed, a variety of traps/exceptions can be trapped and handled by software. A user supplied trap handler routine can be provided for each high/low process priority level. The handler is started when a trap occurs and is given the reason for the trap. The trap handler is not re-entrant and must not cause a trap itself within the same group. All traps are individually maskable.

3.6.1 Trap groups

The trap mechanism is arranged on a per priority basis. For each priority there is a handler for each group of traps, as shown in Figure 3.4.
There are four groups of traps, as detailed below.

- **Breakpoint**
  This group consists of the *Breakpoint* trap. The breakpoint instruction (j0) calls the breakpoint routine via the trap mechanism.

- **Errors**
  The traps in this group are *IntegerError* and *Overflow*. *Overflow* represents arithmetic overflow, such as arithmetic results which do not fit in the result word. *IntegerError* represents errors caused when data is erroneous, for example when a range checking instruction finds that data is out of range.

- **System operations**
  This group consists of the *LoadTrap*, *StoreTrap* and *IllegalOpcode* traps. The *IllegalOpcode* trap is signalled when an attempt is made to execute an illegal instruction. The *LoadTrap* and *StoreTrap* traps allow a kernel to intercept attempts by a monitored process to change or examine trap handlers or trapped process information. It enables a user program to signal to a kernel that it wishes to install a new trap handler.

- **Scheduler**
  The scheduler trap group consists of the *ExternalChannel*, *InternalChannel*, *Timer*, *Timeslice*, *Run*, *Signal*, *ProcessInterrupt* and *QueueEmpty* traps. The *ProcessInterrupt* trap signals that the machine has performed a priority interrupt from low to high. The *QueueEmpty* trap indicates that there is no further executable work to perform. The other traps in this group indicate that the hardware scheduler wants to schedule a process on a process queue, with the different traps enabling the different sources of this to be monitored.

  The scheduler traps enable a software scheduler kernel to use the hardware scheduler to implement a multi-priority software scheduler.

  Note that scheduler traps are different from other traps as they are caused by the micro-scheduler rather than by an executing process.
Trap groups encoding is shown in Table 3.3 below. These codes are used to identify trap groups to various instructions.

<table>
<thead>
<tr>
<th>Trap group</th>
<th>Code</th>
</tr>
</thead>
<tbody>
<tr>
<td>Breakpoint</td>
<td>0</td>
</tr>
<tr>
<td>CPU Errors</td>
<td>1</td>
</tr>
<tr>
<td>System operations</td>
<td>2</td>
</tr>
</tbody>
</table>

Table 3.3 Trap group codes

In addition to the trap groups mentioned above, the **CauseError** flag in the **Status** register is used to signal when a trap condition has been activated by the **causeerror** instruction. It can be used to indicate when trap conditions have occurred due to the user setting them, rather than by the system.

### 3.6.2 Events that can cause traps

Table 3.4 summarizes the events that can cause traps and gives the encoding of bits in the trap **Status** and **Enable** words.

<table>
<thead>
<tr>
<th>Trap cause</th>
<th>Status/Enable codes</th>
<th>Trap group</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>Breakpoint</td>
<td>0</td>
<td>0</td>
<td>When a process executes the breakpoint instruction (j0) then it traps to its trap handler.</td>
</tr>
<tr>
<td>IntegerError</td>
<td>1</td>
<td>1</td>
<td>Integer error other than integer overflow - e.g. explicitly checked or explicitly set error.</td>
</tr>
<tr>
<td>Overflow</td>
<td>2</td>
<td>1</td>
<td>Integer overflow or integer division by zero.</td>
</tr>
<tr>
<td>IllegalOpcode</td>
<td>3</td>
<td>2</td>
<td>Attempt to execute an illegal instruction. This is signalled when opr is executed with an invalid operand.</td>
</tr>
<tr>
<td>LoadTrap</td>
<td>4</td>
<td>2</td>
<td>When the trap descriptor is read with the ldtraph instruction or when the trapped process status is read with the ldtrapped instruction.</td>
</tr>
<tr>
<td>StoreTrap</td>
<td>5</td>
<td>2</td>
<td>When the trap descriptor is written with the sttraph instruction or when the trapped process status is written with the sttrapped instruction.</td>
</tr>
<tr>
<td>InternalChannel</td>
<td>6</td>
<td>3</td>
<td>Scheduler trap from internal channel.</td>
</tr>
<tr>
<td>ExternalChannel</td>
<td>7</td>
<td>3</td>
<td>Scheduler trap from external channel.</td>
</tr>
<tr>
<td>Timer</td>
<td>8</td>
<td>3</td>
<td>Scheduler trap from timer alarm.</td>
</tr>
<tr>
<td>Timeslice</td>
<td>9</td>
<td>3</td>
<td>Scheduler trap from timeslice.</td>
</tr>
<tr>
<td>Run</td>
<td>10</td>
<td>3</td>
<td>Scheduler trap from runp (run process) or startp (start process).</td>
</tr>
<tr>
<td>Signal</td>
<td>11</td>
<td>3</td>
<td>Scheduler trap from signal.</td>
</tr>
<tr>
<td>ProcessInterrupt</td>
<td>12</td>
<td>3</td>
<td>Start executing a process at a new priority level.</td>
</tr>
<tr>
<td>QueueEmpty</td>
<td>13</td>
<td>3</td>
<td>Caused by no process active at a priority level.</td>
</tr>
<tr>
<td>CauseError</td>
<td>15 (Status only)</td>
<td>Any, encoded 0-3</td>
<td>Signals that the causeerror instruction set the trap flag.</td>
</tr>
</tbody>
</table>

Table 3.4 Trap causes and **Status/Enable** codes
3.6.3 Trap handlers

For each trap handler there is a trap handler structure and a trapped process structure. Both the trap handler structure and the trapped process structure are in memory and can be accessed via instructions, see Section 3.6.4.

The trap handler structure specifies what should happen when a trap condition is present, see Table 3.5.

<table>
<thead>
<tr>
<th>Comments</th>
<th>Iptr</th>
<th>Iptr of trap handler process. Base + 3</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Wptr</td>
<td>Wptr of trap handler process. A null Wptr indicates that a trap handler has not been installed. Base + 2</td>
</tr>
<tr>
<td></td>
<td>Status</td>
<td>Contains the Status register that the trap handler starts with. Base + 1</td>
</tr>
<tr>
<td></td>
<td>Enables</td>
<td>Contains a word which encodes the trap enable and global interrupt masks which will be ANDed with the existing masks to allow the trap handler to disable various events while it runs. Base + 0</td>
</tr>
</tbody>
</table>

Table 3.5 Trap handler structure

The trapped process structure saves some of the state of the process that was running when the trap was taken, see Table 3.6.

<table>
<thead>
<tr>
<th>Comments</th>
<th>Iptr</th>
<th>Points to the instruction after the one that caused the trap condition. Base + 3</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Wptr</td>
<td>Wptr of the process that was running when the trap was taken. Base + 2</td>
</tr>
<tr>
<td></td>
<td>Status</td>
<td>The relevant trap bit is set, see Table 3.4 for trap codes. Base + 1</td>
</tr>
<tr>
<td></td>
<td>Enables</td>
<td>Interrupt enables. Base + 0</td>
</tr>
</tbody>
</table>

Table 3.6 Trapped process structure

In addition, for each priority, there is an Enables register and a Status register. The Enables register contains flags to enable each cause of trap. The Status register contains flags to indicate which trap conditions have been detected. The Enables and Status register bit encodings are given in Table 3.4.

A trap will be taken at an interruptible point if a trap is set and the corresponding trap enable bit is set in the Enables register. If the trap is not enabled then nothing is done with the trap condition. If the trap is enabled then the corresponding bit is set in the Status register to indicate the trap condition has occurred.

When a process takes a trap the processor saves the existing Iptr, Wptr, Status and Enables in the trapped process structure. It then loads Iptr, Wptr and Status from the equivalent trap handler structure and ANDs the value in Enables with the value in the structure. This allows the user to disable various events while in the handler, in particular a trap handler must disable all the traps of its trap group to avoid the possibility of a handler trapping to itself.

The trap handler then executes. The values in the trapped process structure can be examined using the ldtrapped instruction (see Section 3.6.4). When the trap handler has completed its operation it returns to the trapped process via the tret (trap return) instruction. This reloads the values saved in the trapped process structure and clears the trap flag in Status.

Note that when a trap handler is started, Areg, Breg and Creg are not saved. The trap handler must save the Areg, Breg, Creg registers using stl (store local).
3.6.4 Trap instructions

Trap handlers and trapped processes can be set up and examined via the ldtraph, sttraph, ldtrapped and sttrapped instructions. Table 3.7 describes the instructions that may be used when dealing with traps.

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Meaning</th>
<th>Use</th>
</tr>
</thead>
<tbody>
<tr>
<td>ldtraph</td>
<td>load trap handler</td>
<td>load the trap handler from memory to the trap handler descriptor</td>
</tr>
<tr>
<td>sttraph</td>
<td>store trap handler</td>
<td>store an existing trap handler descriptor to memory</td>
</tr>
<tr>
<td>ldtrapped</td>
<td>load trapped</td>
<td>load replacement trapped process status from memory</td>
</tr>
<tr>
<td>sttrapped</td>
<td>store trapped</td>
<td>store trapped process status to memory</td>
</tr>
<tr>
<td>trapenb</td>
<td>trap enable</td>
<td>enable traps</td>
</tr>
<tr>
<td>trapdis</td>
<td>trap disable</td>
<td>disable traps</td>
</tr>
<tr>
<td>tret</td>
<td>trap return</td>
<td>used to return from a trap handler</td>
</tr>
<tr>
<td>causeerror</td>
<td>cause error</td>
<td>program can simulate the occurrence of an error</td>
</tr>
</tbody>
</table>

Table 3.7 Instructions which may be used when dealing with traps

The first four instructions transfer data to/from the trap handler structures or trapped process structures from/to an area in memory. In these instructions Areg contains the trap group code (see Table 3.3) and Breg points to the 4 word area of memory used as the source or destination of the transfer. In addition Creg contains the priority of the handler to be installed/examined in the case of ldtraph or sttraph. ldtrapped and sttrapped apply only to the current priority.

If the LoadTrap trap is enabled then ldtraph and ldtrapped do not perform the transfer but set the LoadTrap trap flag. If the StoreTrap trap is enabled then sttraph and sttrapped do not perform the transfer but set the StoreTrap trap flag.

The trap enable masks are encoded by an array of bits (see Table 3.4) which are set to indicate which traps are enabled. This array of bits is stored in the lower half-word of the Enables register. There is an Enables register for each priority. Traps are enabled or disabled by loading a mask into Areg with bits set to indicate which traps are to be affected and the priority to affect in Breg. Executing trapenb ORs the mask supplied in Areg with the trap enables mask in the Enables register for the priority in Breg. Executing trapdis negates the mask supplied in Areg and ANDs it with the trap enables mask in the Enables register for the priority in Breg. Both instructions return the previous value of the trap enables mask in Areg.

3.6.5 Restrictions on trap handlers

There are various restrictions that must be placed on trap handlers to ensure that they work correctly.

1. Trap handlers must not deschedule or timeslice. Trap handlers alter the Enables masks, therefore they must not allow other processes to execute until they have completed.

2. Trap handlers must have their Enable masks set to mask all traps in their trap group to avoid the possibility of a trap handler trapping to itself.

3. Trap handlers must terminate via the tret (trap return) instruction. The only exception to this is that a scheduler kernel may use restart to return to a previously shadowed process.
4 Interrupt controller

The ST20450 supports external interrupts, enabling an on-chip subsystem or external interrupt pin to interrupt the currently running process in order to run an interrupt handling process.

The ST20450 interrupt subsystem supports eight prioritized interrupts. This allows nested pre-emptive interrupts for real-time system design.

All interrupts have a higher priority than the high priority process queue. Each interrupt level has a higher priority than the previous (interrupt 7 is the highest priority, interrupt 0 is lowest priority) and each level supports only one software handler process.

Interrupts on the ST20450 are implemented via an on-chip interrupt controller peripheral. An interrupt can be signalled to the controller by one of the following:

- a signal on an external **Interrupt0-7** pin
- software asserting an interrupt in a bit mask
4.1 Interrupt vector table

Each interrupt level has an external **Interrupt** pin to trigger it and a vector table used to associate a software handler with the interrupt level.

The interrupt controller contains a table of pointers to interrupt handlers. Each interrupt handler is represented by its workspace pointer (\textit{Wptr}). The table contains a workspace pointer for each level of interrupt.

The \textit{Wptr} gives access to the code, data and interrupt save space of the interrupt handler. The position of the \textit{Wptr} in the interrupt table implies the priority of the interrupt.

Run-time library support is provided for setting and programming the vector table.

4.2 Interrupt handlers

At any interruptible point in its execution the CPU can receive an interrupt request from the interrupt controller. The CPU immediately acknowledges the request.

In response to receiving an interrupt the CPU performs a procedure call to the process in the vector table. The state of the interrupted process is stored in the workspace of the interrupt handler as shown in Figure 4.2. Each interrupt level has its own workspace.

![Figure 4.2 State of interrupted process](image)

The interrupt routine is initialized with space below \textit{Wptr}. The \textit{Iptr} and \textit{Status} word for the routine are stored there permanently. This should be programmed before the \textit{Wptr} is written into the vector table. The behavior of the interrupt differs depending on the priority of the CPU when the interrupt occurs.
When an interrupt occurs when the CPU was running at high priority, the CPU saves the current process state (Areg, Breg, Creg, Wptr, Iptr and Status) into the workspace of the interrupt handler. The value HandlerWptr, which is stored in the interrupt controller, points to the top of this workspace. The values of Iptr and Status to be used by the interrupt handler are loaded from this workspace and starts executing the handler. The value of Wptr is then set to the bottom of this save area.

When an interrupt occurs when the CPU was idle or running at low priority, the Status is saved. This indicates that no valid process is running (Null Status). The interrupted processes (low priority process) state is stored in shadow registers. This state can be accessed via the ldshadow and stshadow instructions. The interrupt handler is then run at high priority.

When the interrupt routine has completed it must adjust Wptr to the value at the start of the handler code and then execute the iret (interrupt return) instruction. This restores the interrupted state from the interrupt handler structure and signals to the interrupt controller that the interrupt has completed. The processor will then continue from where it was before being interrupted.

### 4.3 Interrupt latency

The interrupt latency is dependant on the data being accessed and the position of the interrupt handler and the interrupted process. This allows systems to be designed with the best trade-off use of fast internal memory and interrupt latency.

### 4.4 Pre-emption and interrupt priority

Each interrupt channel has an implied priority fixed by its place in the interrupt vector table. All interrupts will cause scheduled processes of any priority to be suspended and the interrupt handler started. Once an interrupt has been sent from the controller to the CPU the controller keeps a record of the current executing interrupt priority. This is only cleared when the interrupt handler executes a return from interrupt (iret) instruction. Interrupts of a lower priority arriving will be blocked by the interrupt controller until the interrupt priority has descended to such a level that the routine will execute. An interrupt of a higher priority than the currently executing handler will be passed to the CPU and cause the current handler to be suspended until the higher priority interrupt is serviced.

In this way interrupts can be nested and a higher priority interrupt will always pre-empt a lower priority one. Deep nesting and placing frequent interrupts at high priority can result in a system where low priority interrupts are never serviced or the controller and CPU time are consumed in nesting interrupt priorities and not executing the interrupt handlers.
4.5 Restrictions on interrupt handlers

There are various restrictions that must be placed on interrupt handlers to ensure that they interact correctly with the rest of the process model implemented in the CPU.

1. Interrupt handlers must not deschedule.
2. Interrupt handlers must not execute communication instructions. However they may communicate with other processes through shared variables using the semaphore signal to synchronize.
3. Interrupt handlers must not perform block move instructions.
4. Interrupt handlers must not cause program traps. However they may be trapped by a scheduler trap.

4.6 Interrupt configuration registers

The interrupt controller is allocated a 4k block of memory in the internal peripheral address space. Information on interrupts is stored in registers as detailed in the following section. The registers can be examined and set by the devlw (device load word) and devsw (device store word) instructions. Note, they can not be accessed using memory instructions.

4.6.1 HandlerWptr0-7 registers

The HandlerWptr0-7 registers (1 per interrupt) contain a pointer to the workspace of the interrupt handler.

Note, before the interrupt is enabled, by writing a 1 in the Mask register, the user (or toolset) must ensure that there is a valid Wptr in the register.

<table>
<thead>
<tr>
<th>Bit field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>HandlerWptr</td>
</tr>
<tr>
<td>1:0</td>
<td>Reserved. Write 0.</td>
</tr>
</tbody>
</table>

Table 4.1 Bit fields in the HandlerWptr0-7 registers - one register per interrupt

4.6.2 TriggerMode0-7 registers

Each interrupt channel can be programmed to trigger on rising/falling edges or high/low levels on the external Interrupt pin.
Table 4.2 Bit fields in the TriggerMode0-7 registers - one register per interrupt

Note, level triggering is different to edge triggering in that if the input is held at the triggering level, a continuous stream of interrupts is generated.

4.6.3 Mask register

An interrupt mask register is provided in the interrupt controller to selectively enable or disable external interrupts. This mask register also includes a global interrupt disable bit to disable all external interrupts whatever the state of the individual interrupt mask bits.

To complement this the interrupt controller also includes an interrupt pending register which contains a pending flag for each interrupt channel. The Mask register performs a masking function on the Pending register to give control over what is allowed to interrupt the CPU while retaining the ability to continually monitor external interrupts.

On start-up, the Mask register is initialized to zero’s, thus all interrupts are disabled, both globally and individually. When a 1 is written to the GlobalEnable bit, the individual interrupt bits are still disabled and must also have a 1 individually written to them to enable them.

Table 4.3 Bit fields in the Mask register
The **Mask** register is mapped onto two additional addresses so that bits can be set or cleared individually.

**Set-Mask** (address #200000C4) allows bits to be set individually. Writing a ‘1’ in this register sets the corresponding bit in the **Mask** register, a ‘0’ leaves the bit unchanged.

**Clear-Mask** (address #200000C8) allows bits to be cleared individually. Writing a ‘1’ in this register resets the corresponding bit in the **Mask** register, a ‘0’ leaves the bit unchanged.

### 4.6.4 Pending register

The **Pending** register is an 8 bit register with each bit controlled by the corresponding interrupt pin. A read can be used to examine the state of the interrupt controller while a write can be used to explicitly trigger an interrupt.

A bit is set when the triggering condition for an interrupt is met. All bits are independent so that several bits can be set in the same cycle. Once a bit is set, a further triggering condition will have no effect. The triggering condition is independent of the **Mask** register.

The highest priority interrupt bit is reset once the interrupt controller has made an interrupt request to the CPU.

The interrupt controller receives external interrupt requests and makes an interrupt request to the CPU when it has a pending interrupt request of higher priority than the currently executing interrupt handler.

<table>
<thead>
<tr>
<th>Pending</th>
<th>#20000080</th>
<th>Read/Write</th>
</tr>
</thead>
<tbody>
<tr>
<td>Bit</td>
<td>Bit field</td>
<td>Function</td>
</tr>
<tr>
<td>0</td>
<td>PendingInt0</td>
<td>Interrupt 0 pending bit.</td>
</tr>
<tr>
<td>1</td>
<td>PendingInt1</td>
<td>Interrupt 1 pending bit.</td>
</tr>
<tr>
<td>2</td>
<td>PendingInt2</td>
<td>Interrupt 2 pending bit.</td>
</tr>
<tr>
<td>3</td>
<td>PendingInt3</td>
<td>Interrupt 3 pending bit.</td>
</tr>
<tr>
<td>4</td>
<td>PendingInt4</td>
<td>Interrupt 4 pending bit.</td>
</tr>
<tr>
<td>5</td>
<td>PendingInt5</td>
<td>Interrupt 5 pending bit.</td>
</tr>
<tr>
<td>6</td>
<td>PendingInt6</td>
<td>Interrupt 6 pending bit.</td>
</tr>
<tr>
<td>7</td>
<td>PendingInt7</td>
<td>Interrupt 7 pending bit.</td>
</tr>
</tbody>
</table>

Table 4.4 Bit fields in the **Pending** register

The **Pending** register is mapped onto two additional addresses so that bits can be set or cleared individually.

**Set-Pending** (address #20000084) allows bits to be set individually. Writing a ‘1’ in this register sets the corresponding bit in the **Pending** register, a ‘0’ leaves the bit unchanged.

**Clear-Pending** (address #20000088) allows bits to be cleared individually. Writing a ‘1’ in this register resets the corresponding bit in the **Pending** register, a ‘0’ leaves the bit unchanged.

Note, if the CPU wants to write or clear some bits of the **Pending** register, the interrupts should be masked (by writing or clearing the **Mask** register) before writing or clearing the **Pending** register. The interrupts can then be unmasked.
4.6.5 Exec register

The Exec register is an 8 bit register which keeps track of the currently executing and pre-empted interrupts. A bit is set when the CPU starts running code for that interrupt. The highest priority interrupt bit is reset once the interrupt handler executes a return from interrupt (iret).

<table>
<thead>
<tr>
<th>Bit</th>
<th>Bit field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Interrupt0Exec</td>
<td>Set to 1 when the CPU starts running code for interrupt 0.</td>
</tr>
<tr>
<td>1</td>
<td>Interrupt1Exec</td>
<td>Set to 1 when the CPU starts running code for interrupt 1.</td>
</tr>
<tr>
<td>2</td>
<td>Interrupt2Exec</td>
<td>Set to 1 when the CPU starts running code for interrupt 2.</td>
</tr>
<tr>
<td>3</td>
<td>Interrupt3Exec</td>
<td>Set to 1 when the CPU starts running code for interrupt 3.</td>
</tr>
<tr>
<td>4</td>
<td>Interrupt4Exec</td>
<td>Set to 1 when the CPU starts running code for interrupt 4.</td>
</tr>
<tr>
<td>5</td>
<td>Interrupt5Exec</td>
<td>Set to 1 when the CPU starts running code for interrupt 5.</td>
</tr>
<tr>
<td>6</td>
<td>Interrupt6Exec</td>
<td>Set to 1 when the CPU starts running code for interrupt 6.</td>
</tr>
<tr>
<td>7</td>
<td>Interrupt7Exec</td>
<td>Set to 1 when the CPU starts running code for interrupt 7.</td>
</tr>
</tbody>
</table>

Table 4.5 Bit fields in the Exec register

The Exec register is mapped onto two additional addresses so that bits can be set or cleared individually.

**Set-Exec** (address #20000104) allows bits to be set individually. Writing a ‘1’ in this register sets the corresponding bit in the Exec register, a ‘0’ leaves the bit unchanged.

**Clear-Exec** (address #20000108) allows bits to be cleared individually. Writing a ‘1’ in this register resets the corresponding bit in the Exec register, a ‘0’ leaves the bit unchanged.
5 Instruction set

This chapter provides information on the instruction set. It contains tables listing all the instructions, and where applicable provides details of the number of processor cycles taken by an instruction.

The instruction set has been designed for simple and efficient compilation of high-level languages. All instructions have the same format, designed to give a compact representation of the operations occurring most frequently in programs.

Each instruction consists of a single byte divided into two 4-bit parts. The four most significant bits (MSB) of the byte are a function code and the four least significant bits (LSB) are a data value, as shown in Figure 5.1.

![Figure 5.1 Instruction format](image)

For further information on the instruction set refer to the *ST20 Instruction Set Manual (document number 72-TRN-273-00)*.

5.1 Instruction cycles

Timing information is available for some instructions. However, it should be noted that many instructions have ranges of timings which are data dependent.

Where included, timing information is based on the number of clock cycles assuming any memory accesses are to 2 cycle internal memory and no other subsystem is using memory. Actual time will be dependent on the speed of external memory and memory bus availability.

Note that the actual time can be increased by:

1. the instruction requiring a value on the register stack from the final memory read in the previous instruction – the current instruction will stall until the value becomes available.
2. the first memory operation in the current instruction can be delayed while a preceding memory operation completes - any two memory operations can be in progress at any time, any further operation will stall until the first completes.
3. memory operations in current instructions can be delayed by access by instruction fetch or subsystems to the memory interface.
4. there can be a delay between instructions while the instruction fetch unit fetches and partially decodes the next instruction – this will be the case whenever an instruction causes the instruction flow to jump.

Note that the instruction timings given refer to ‘standard’ behavior and may be different if, for example, traps are set by the instruction.
5.2 Instruction characteristics

The Primary Instructions Table 5.3 gives the basic function code. Where the operand is less than 16, a single byte encodes the complete instruction. If the operand is greater than 15, one prefix instruction ($pfix$) is required for each additional four bits of the operand. If the operand is negative the first prefix instruction will be $nfix$. Examples of $pfix$ and $nfix$ coding are given in Table 5.1.

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Function code</th>
<th>Memory code</th>
</tr>
</thead>
<tbody>
<tr>
<td>ldc #3</td>
<td>#4</td>
<td>#43</td>
</tr>
<tr>
<td>ldc #35</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

is coded as

| $pfix$ | #3 | #2 | #23 |
| ldc #5 | #4 |    | #45 |

ldc #987

is coded as

| $pfix$ | #9 | #2 | #29 |
| $pfix$ | #8 | #2 | #28 |
| ldc #7 | #4 |    | #47 |

ldc #7 #4 #47

ldc #7 #4 #47

ldc -31 (ldc #FFFFFFE1)

is coded as

| $nfix$ | #1 | #6 | #61 |
| ldc #1 | #4 |    | #41 |

Table 5.1 Prefix coding

Any instruction which is not in the instruction set tables is an invalid instruction and is flagged illegal, returning an error code to the trap handler, if loaded and enabled.

The Notes column of the tables indicates the descheduling and error features of an instruction as described in Table 5.2.

<table>
<thead>
<tr>
<th>Ident</th>
<th>Feature</th>
</tr>
</thead>
<tbody>
<tr>
<td>E</td>
<td>Instruction can set an IntegerError trap</td>
</tr>
<tr>
<td>L</td>
<td>Instruction can cause a LoadTrap trap</td>
</tr>
<tr>
<td>S</td>
<td>Instruction can cause a StoreTrap trap</td>
</tr>
<tr>
<td>O</td>
<td>Instruction can cause an Overflow trap</td>
</tr>
<tr>
<td>I</td>
<td>Interruptible instruction</td>
</tr>
<tr>
<td>A</td>
<td>Instruction can be aborted and later restarted.</td>
</tr>
<tr>
<td>D</td>
<td>Instruction can deschedule</td>
</tr>
<tr>
<td>T</td>
<td>Instruction can timeslice</td>
</tr>
</tbody>
</table>

Table 5.2 Instruction features
## 5.3 Instruction set tables

<table>
<thead>
<tr>
<th>Function code</th>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0X</td>
<td>j</td>
<td>7</td>
<td>jump</td>
<td>D, T</td>
</tr>
<tr>
<td>1</td>
<td>1X</td>
<td>ldlp</td>
<td>1</td>
<td>load local pointer</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>2X</td>
<td>pfix</td>
<td>0 to 3</td>
<td>prefix</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>3X</td>
<td>ldnl</td>
<td>1</td>
<td>load non-local</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>4X</td>
<td>ldc</td>
<td>1</td>
<td>load constant</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>5X</td>
<td>ldnlp</td>
<td>1</td>
<td>load non-local pointer</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>6X</td>
<td>nfix</td>
<td>0 to 3</td>
<td>negative prefix</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>7X</td>
<td>ld1</td>
<td>1</td>
<td>load local</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>8X</td>
<td>adc</td>
<td>2 to 3</td>
<td>add constant</td>
<td>O</td>
</tr>
<tr>
<td>9</td>
<td>9X</td>
<td>call</td>
<td>8</td>
<td>call</td>
<td></td>
</tr>
<tr>
<td>A</td>
<td>AX</td>
<td>cj</td>
<td>1 or 7</td>
<td>conditional jump</td>
<td></td>
</tr>
<tr>
<td>B</td>
<td>BX</td>
<td>ajw</td>
<td>2</td>
<td>adjust workspace</td>
<td></td>
</tr>
<tr>
<td>C</td>
<td>CX</td>
<td>eqc</td>
<td>1</td>
<td>equals constant</td>
<td></td>
</tr>
<tr>
<td>D</td>
<td>DX</td>
<td>stl</td>
<td>1</td>
<td>store local</td>
<td></td>
</tr>
<tr>
<td>E</td>
<td>EX</td>
<td>stnl</td>
<td>2</td>
<td>store non-local</td>
<td></td>
</tr>
<tr>
<td>F</td>
<td>FX</td>
<td>opr</td>
<td>0</td>
<td>operate</td>
<td></td>
</tr>
</tbody>
</table>

Table 5.3 Primary functions

<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>22FA</td>
<td>testpranal</td>
<td>1</td>
<td>test processor analyzing</td>
<td></td>
</tr>
<tr>
<td>23FE</td>
<td>saveh</td>
<td>3</td>
<td>save high priority queue registers</td>
<td></td>
</tr>
<tr>
<td>23FD</td>
<td>savel</td>
<td>3</td>
<td>save low priority queue registers</td>
<td></td>
</tr>
<tr>
<td>21F8</td>
<td>sthf</td>
<td>1</td>
<td>store high priority front pointer</td>
<td></td>
</tr>
<tr>
<td>25F0</td>
<td>sthb</td>
<td>1</td>
<td>store high priority back pointer</td>
<td></td>
</tr>
<tr>
<td>21FC</td>
<td>stlf</td>
<td>1</td>
<td>store low priority front pointer</td>
<td></td>
</tr>
<tr>
<td>21F7</td>
<td>stllb</td>
<td>1</td>
<td>store low priority back pointer</td>
<td></td>
</tr>
<tr>
<td>25F4</td>
<td>sttimer</td>
<td>2</td>
<td>store timer</td>
<td></td>
</tr>
<tr>
<td>2127FC</td>
<td>lddevid</td>
<td>1</td>
<td>load device identity</td>
<td></td>
</tr>
<tr>
<td>27FE</td>
<td>ldmemstartval</td>
<td>1</td>
<td>load value of MemStart address</td>
<td></td>
</tr>
</tbody>
</table>

Table 5.4 Processor initialization operation codes
<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>24F6</td>
<td>and</td>
<td>1</td>
<td>and</td>
<td></td>
</tr>
<tr>
<td>24FB</td>
<td>or</td>
<td>1</td>
<td>or</td>
<td></td>
</tr>
<tr>
<td>23F3</td>
<td>xor</td>
<td>1</td>
<td>exclusive or</td>
<td></td>
</tr>
<tr>
<td>23F2</td>
<td>not</td>
<td>1</td>
<td>bitwise not</td>
<td></td>
</tr>
<tr>
<td>24F1</td>
<td>shl</td>
<td>1</td>
<td>shift left</td>
<td></td>
</tr>
<tr>
<td>24F0</td>
<td>shr</td>
<td>1</td>
<td>shift right</td>
<td></td>
</tr>
<tr>
<td>F5</td>
<td>add</td>
<td>2</td>
<td>add</td>
<td>A, O</td>
</tr>
<tr>
<td>FC</td>
<td>sub</td>
<td>2</td>
<td>subtract</td>
<td>A, O</td>
</tr>
<tr>
<td>25F3</td>
<td>mul</td>
<td>3</td>
<td>multiply</td>
<td>A, O</td>
</tr>
<tr>
<td>27F2</td>
<td>fmul</td>
<td>5</td>
<td>fractional multiply</td>
<td>A, O</td>
</tr>
<tr>
<td>22FC</td>
<td>div</td>
<td>4 to 35</td>
<td>divide</td>
<td>A, O</td>
</tr>
<tr>
<td>21FF</td>
<td>rem</td>
<td>3 to 35</td>
<td>remainder</td>
<td>A, O</td>
</tr>
<tr>
<td>F9</td>
<td>gt</td>
<td>2</td>
<td>greater than</td>
<td>A</td>
</tr>
<tr>
<td>25FF</td>
<td>gtu</td>
<td>2</td>
<td>greater than unsigned</td>
<td>A</td>
</tr>
<tr>
<td>F4</td>
<td>diff</td>
<td>1</td>
<td>difference</td>
<td></td>
</tr>
<tr>
<td>25F2</td>
<td>sum</td>
<td>1</td>
<td>sum</td>
<td></td>
</tr>
<tr>
<td>F8</td>
<td>prod</td>
<td>3</td>
<td>product</td>
<td>A</td>
</tr>
<tr>
<td>26F8</td>
<td>satadd</td>
<td>2 to 3</td>
<td>saturating add</td>
<td>A</td>
</tr>
<tr>
<td>26F9</td>
<td>satsub</td>
<td>2 to 3</td>
<td>saturating subtract</td>
<td>A</td>
</tr>
<tr>
<td>26FA</td>
<td>satmul</td>
<td>4</td>
<td>saturating multiply</td>
<td>A</td>
</tr>
</tbody>
</table>

Table 5.5 Arithmetic/logical operation codes

<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>21F6</td>
<td>ladd</td>
<td>2</td>
<td>long add</td>
<td>A, O</td>
</tr>
<tr>
<td>23F8</td>
<td>lsub</td>
<td>2</td>
<td>long subtract</td>
<td>A, O</td>
</tr>
<tr>
<td>23F7</td>
<td>lsum</td>
<td>1</td>
<td>long sum</td>
<td></td>
</tr>
<tr>
<td>24FF</td>
<td>ldiff</td>
<td>1</td>
<td>long diff</td>
<td></td>
</tr>
<tr>
<td>23F1</td>
<td>lmul</td>
<td>4</td>
<td>long multiply</td>
<td>A</td>
</tr>
<tr>
<td>21FA</td>
<td>ldiv</td>
<td>3 to 35</td>
<td>long divide</td>
<td>A, O</td>
</tr>
<tr>
<td>23F6</td>
<td>lshl</td>
<td>2</td>
<td>long shift left</td>
<td>A</td>
</tr>
<tr>
<td>23F5</td>
<td>lshr</td>
<td>2</td>
<td>long shift right</td>
<td>A</td>
</tr>
<tr>
<td>21F9</td>
<td>norm</td>
<td>3</td>
<td>normalize</td>
<td>A</td>
</tr>
<tr>
<td>26F4</td>
<td>slmul</td>
<td>4</td>
<td>signed long multiply</td>
<td>A, O</td>
</tr>
<tr>
<td>26F5</td>
<td>sulmul</td>
<td>4</td>
<td>signed times unsigned long multiply</td>
<td>A, O</td>
</tr>
</tbody>
</table>

Table 5.6 Long arithmetic operation codes
<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>F0</td>
<td>rev</td>
<td>1</td>
<td>reverse</td>
<td></td>
</tr>
<tr>
<td>23FA</td>
<td>xword</td>
<td>3</td>
<td>extend to word</td>
<td>A</td>
</tr>
<tr>
<td>25F6</td>
<td>cword</td>
<td>2 to 3</td>
<td>check word</td>
<td>A, E</td>
</tr>
<tr>
<td>21FD</td>
<td>xdbl</td>
<td>1</td>
<td>extend to double</td>
<td></td>
</tr>
<tr>
<td>24FC</td>
<td>csngl</td>
<td>2</td>
<td>check single</td>
<td>A, E</td>
</tr>
<tr>
<td>24F2</td>
<td>mint</td>
<td>1</td>
<td>minimum integer</td>
<td></td>
</tr>
<tr>
<td>25FA</td>
<td>dup</td>
<td>1</td>
<td>duplicate top of stack</td>
<td></td>
</tr>
<tr>
<td>27F9</td>
<td>pop</td>
<td>1</td>
<td>pop processor stack</td>
<td></td>
</tr>
<tr>
<td>68FD</td>
<td>reboot</td>
<td>2</td>
<td>reboot</td>
<td></td>
</tr>
</tbody>
</table>

Table 5.7 General operation codes

<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>F2</td>
<td>bsub</td>
<td>1</td>
<td>byte subscript</td>
<td></td>
</tr>
<tr>
<td>FA</td>
<td>wsub</td>
<td>1</td>
<td>word subscript</td>
<td></td>
</tr>
<tr>
<td>28F1</td>
<td>wsubdb</td>
<td>1</td>
<td>form double word subscript</td>
<td></td>
</tr>
<tr>
<td>23F4</td>
<td>bcnt</td>
<td>1</td>
<td>byte count</td>
<td></td>
</tr>
<tr>
<td>23FF</td>
<td>wcnt</td>
<td>1</td>
<td>word count</td>
<td></td>
</tr>
<tr>
<td>F1</td>
<td>lb</td>
<td>1</td>
<td>load byte</td>
<td></td>
</tr>
<tr>
<td>23FB</td>
<td>sb</td>
<td>2</td>
<td>store byte</td>
<td></td>
</tr>
<tr>
<td>24FA</td>
<td>move</td>
<td></td>
<td>move message</td>
<td>I</td>
</tr>
</tbody>
</table>

Table 5.8 Indexing/array operation codes

<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>22F2</td>
<td>ldtimer</td>
<td>1</td>
<td>load timer</td>
<td></td>
</tr>
<tr>
<td>22FB</td>
<td>tin</td>
<td></td>
<td>timer input</td>
<td>I</td>
</tr>
<tr>
<td>24FE</td>
<td>talt</td>
<td>3</td>
<td>timer alt start</td>
<td></td>
</tr>
<tr>
<td>25F1</td>
<td>taltwt</td>
<td></td>
<td>timer alt wait</td>
<td>D, I</td>
</tr>
<tr>
<td>24F7</td>
<td>enbt</td>
<td>1 to 7</td>
<td>enable timer</td>
<td></td>
</tr>
<tr>
<td>22FE</td>
<td>dist</td>
<td></td>
<td>disable timer</td>
<td>I</td>
</tr>
</tbody>
</table>

Table 5.9 Timer handling operation codes
<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>F7</td>
<td>in</td>
<td></td>
<td>input message</td>
<td></td>
</tr>
<tr>
<td>FB</td>
<td>out</td>
<td></td>
<td>output message</td>
<td></td>
</tr>
<tr>
<td>FF</td>
<td>outword</td>
<td></td>
<td>output word</td>
<td></td>
</tr>
<tr>
<td>FE</td>
<td>outbyte</td>
<td></td>
<td>output byte</td>
<td></td>
</tr>
<tr>
<td>24F3</td>
<td>alt</td>
<td>2</td>
<td>alt start</td>
<td></td>
</tr>
<tr>
<td>24F4</td>
<td>altwt</td>
<td>3 to 6</td>
<td>alt wait</td>
<td></td>
</tr>
<tr>
<td>24F5</td>
<td>altend</td>
<td>8</td>
<td>alt end</td>
<td></td>
</tr>
<tr>
<td>24F9</td>
<td>enbs</td>
<td>1 to 2</td>
<td>enable skip</td>
<td></td>
</tr>
<tr>
<td>23F0</td>
<td>diss</td>
<td>1</td>
<td>disable skip</td>
<td></td>
</tr>
<tr>
<td>21F2</td>
<td>resetch</td>
<td>3</td>
<td>reset channel</td>
<td></td>
</tr>
<tr>
<td>24F8</td>
<td>enbc</td>
<td>1 to 4</td>
<td>enable channel</td>
<td></td>
</tr>
<tr>
<td>22FF</td>
<td>disc</td>
<td>1 to 6</td>
<td>disable channel</td>
<td></td>
</tr>
</tbody>
</table>

Table 5.10  Input and output operation codes

<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>22F0</td>
<td>ret</td>
<td>2</td>
<td>return</td>
<td></td>
</tr>
<tr>
<td>21FB</td>
<td>ldpi</td>
<td>1</td>
<td>load pointer to instruction</td>
<td></td>
</tr>
<tr>
<td>23FC</td>
<td>gajw</td>
<td>2 to 3</td>
<td>general adjust workspace</td>
<td></td>
</tr>
<tr>
<td>F6</td>
<td>gcall</td>
<td>6</td>
<td>general call</td>
<td></td>
</tr>
<tr>
<td>22F1</td>
<td>lend</td>
<td>4 to 5</td>
<td>loop end</td>
<td>T</td>
</tr>
</tbody>
</table>

Table 5.11  Control operation codes

<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>FD</td>
<td>startp</td>
<td>5 to 6</td>
<td>start process</td>
<td></td>
</tr>
<tr>
<td>F3</td>
<td>endp</td>
<td>4 to 6</td>
<td>end process</td>
<td></td>
</tr>
<tr>
<td>23F9</td>
<td>runp</td>
<td>3</td>
<td>run process</td>
<td></td>
</tr>
<tr>
<td>21F5</td>
<td>stopp</td>
<td>2</td>
<td>stop process</td>
<td></td>
</tr>
<tr>
<td>21FE</td>
<td>ldpri</td>
<td>1</td>
<td>load current priority</td>
<td></td>
</tr>
</tbody>
</table>

Table 5.12  Scheduling operation codes
<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>21F3</td>
<td>csub0</td>
<td>2</td>
<td>check subscript from 0</td>
<td>A, E</td>
</tr>
<tr>
<td>24FD</td>
<td>ccnt1</td>
<td>2</td>
<td>check count from 1</td>
<td>A, E</td>
</tr>
<tr>
<td>22F9</td>
<td>testerr</td>
<td>1</td>
<td>test error false and clear</td>
<td></td>
</tr>
<tr>
<td>21F0</td>
<td>seterr</td>
<td>1</td>
<td>set error</td>
<td></td>
</tr>
<tr>
<td>25F5</td>
<td>stoperr</td>
<td>1 to 3</td>
<td>stop on error (no error)</td>
<td>D</td>
</tr>
<tr>
<td>25F7</td>
<td>clrhaltterr</td>
<td>2</td>
<td>clear halt-on-error</td>
<td></td>
</tr>
<tr>
<td>25F8</td>
<td>sethaltterr</td>
<td>1</td>
<td>set halt-on-error</td>
<td></td>
</tr>
<tr>
<td>25F9</td>
<td>testhaltterr</td>
<td>1</td>
<td>test halt-on-error</td>
<td></td>
</tr>
</tbody>
</table>

Table 5.13  Error handling operation codes

<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>25FB</td>
<td>move2dinit</td>
<td>1</td>
<td>initialize data for 2D block move</td>
<td></td>
</tr>
<tr>
<td>25FC</td>
<td>move2dall</td>
<td>2</td>
<td>2D block copy</td>
<td>I</td>
</tr>
<tr>
<td>25FD</td>
<td>move2dnonzero</td>
<td>2</td>
<td>2D block copy non-zero bytes</td>
<td>I</td>
</tr>
<tr>
<td>25FE</td>
<td>move2dzero</td>
<td>2</td>
<td>2D block copy zero bytes</td>
<td>I</td>
</tr>
</tbody>
</table>

Table 5.14  2D block move operation codes

<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>27F4</td>
<td>crcword</td>
<td>34</td>
<td>calculate crc on word</td>
<td>A</td>
</tr>
<tr>
<td>27F5</td>
<td>crcbyte</td>
<td>10</td>
<td>calculate crc on byte</td>
<td>A</td>
</tr>
<tr>
<td>27F6</td>
<td>bitcnt</td>
<td>3</td>
<td>count bits set in word</td>
<td>A</td>
</tr>
<tr>
<td>27F7</td>
<td>bitreword</td>
<td>1</td>
<td>reverse bits in word</td>
<td>A</td>
</tr>
<tr>
<td>27F8</td>
<td>bitrewnbits</td>
<td>2</td>
<td>reverse bottom n bits in word</td>
<td>A</td>
</tr>
</tbody>
</table>

Table 5.15  CRC and bit operation codes

<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>27F3</td>
<td>cflerr</td>
<td>2</td>
<td>check floating point error</td>
<td>E</td>
</tr>
<tr>
<td>29FC</td>
<td>fpstesterr</td>
<td>1</td>
<td>load value true (FPU not present)</td>
<td></td>
</tr>
<tr>
<td>26F3</td>
<td>unpacksn</td>
<td>4</td>
<td>unpack single length floating point number</td>
<td>A</td>
</tr>
<tr>
<td>26FD</td>
<td>roundsn</td>
<td>7</td>
<td>round single length floating point number</td>
<td>A</td>
</tr>
<tr>
<td>26FC</td>
<td>postnormsn</td>
<td>7 to 8</td>
<td>post-normalize correction of single length floating point number</td>
<td>A</td>
</tr>
<tr>
<td>27F1</td>
<td>ldinf</td>
<td>1</td>
<td>load single length infinity</td>
<td></td>
</tr>
</tbody>
</table>

Table 5.16  Floating point support operation codes
<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>2CF7</td>
<td>cir</td>
<td>2 to 4</td>
<td>check in range</td>
<td>A, E</td>
</tr>
<tr>
<td>2CFC</td>
<td>ciru</td>
<td>2 to 4</td>
<td>check in range unsigned</td>
<td>A, E</td>
</tr>
<tr>
<td>2BFA</td>
<td>cb</td>
<td>2 to 3</td>
<td>check byte</td>
<td>A, E</td>
</tr>
<tr>
<td>2BF8</td>
<td>cbu</td>
<td>2 to 3</td>
<td>check byte unsigned</td>
<td>A, E</td>
</tr>
<tr>
<td>2FFA</td>
<td>cs</td>
<td>2 to 3</td>
<td>check sixteen</td>
<td>A, E</td>
</tr>
<tr>
<td>2FFB</td>
<td>csu</td>
<td>2 to 3</td>
<td>check sixteen unsigned</td>
<td>A, E</td>
</tr>
<tr>
<td>2FF8</td>
<td>xsword</td>
<td>2</td>
<td>sign extend sixteen to word</td>
<td>A</td>
</tr>
<tr>
<td>2BF8</td>
<td>xbword</td>
<td>3</td>
<td>sign extend byte to word</td>
<td>A</td>
</tr>
</tbody>
</table>

Table 5.17 Range checking and conversion instructions

<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>2CF1</td>
<td>ssub</td>
<td>1</td>
<td>sixteen subscript</td>
<td></td>
</tr>
<tr>
<td>2CFA</td>
<td>ls</td>
<td>1</td>
<td>load sixteen</td>
<td></td>
</tr>
<tr>
<td>2CF8</td>
<td>ss</td>
<td>2</td>
<td>store sixteen</td>
<td></td>
</tr>
<tr>
<td>2BF9</td>
<td>lbx</td>
<td>1</td>
<td>load byte and sign extend</td>
<td></td>
</tr>
<tr>
<td>2FF9</td>
<td>lsx</td>
<td>1</td>
<td>load sixteen and sign extend</td>
<td></td>
</tr>
</tbody>
</table>

Table 5.18 Indexing/array instructions

<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>2FF0</td>
<td>devlb</td>
<td>3</td>
<td>device load byte</td>
<td>A</td>
</tr>
<tr>
<td>2FF2</td>
<td>devls</td>
<td>3</td>
<td>device load sixteen</td>
<td>A</td>
</tr>
<tr>
<td>2FF4</td>
<td>devlw</td>
<td>3</td>
<td>device load word</td>
<td>A</td>
</tr>
<tr>
<td>62F4</td>
<td>devmove</td>
<td>3</td>
<td>device move</td>
<td>I</td>
</tr>
<tr>
<td>2FF1</td>
<td>devs</td>
<td>3</td>
<td>device store byte</td>
<td>A</td>
</tr>
<tr>
<td>2FF3</td>
<td>devss</td>
<td>3</td>
<td>device store sixteen</td>
<td>A</td>
</tr>
<tr>
<td>2FF5</td>
<td>devsw</td>
<td>3</td>
<td>device store word</td>
<td>A</td>
</tr>
</tbody>
</table>

Table 5.19 Device access instructions

<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>60F5</td>
<td>wait</td>
<td>4 to 10</td>
<td>wait</td>
<td>D</td>
</tr>
<tr>
<td>60F4</td>
<td>signal</td>
<td>6 to 10</td>
<td>signal</td>
<td></td>
</tr>
</tbody>
</table>

Table 5.20 Semaphore instructions
<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>60F0</td>
<td>swapqueue</td>
<td>3</td>
<td>swap scheduler queue</td>
<td></td>
</tr>
<tr>
<td>60F1</td>
<td>swaptimer</td>
<td>5</td>
<td>swap timer queue</td>
<td></td>
</tr>
<tr>
<td>60F2</td>
<td>insertqueue</td>
<td>1 to 2</td>
<td>insert at front of scheduler queue</td>
<td></td>
</tr>
<tr>
<td>60F3</td>
<td>timeslice</td>
<td>3 to 4</td>
<td>timeslice</td>
<td></td>
</tr>
<tr>
<td>60FC</td>
<td>ldshadow</td>
<td>6 to 23</td>
<td>load shadow registers</td>
<td>A</td>
</tr>
<tr>
<td>60FD</td>
<td>stshadow</td>
<td>5 to 17</td>
<td>store shadow registers</td>
<td>A</td>
</tr>
<tr>
<td>62FE</td>
<td>restart</td>
<td>19</td>
<td>restart</td>
<td></td>
</tr>
<tr>
<td>62FF</td>
<td>causeerror</td>
<td>2</td>
<td>cause error</td>
<td></td>
</tr>
<tr>
<td>61FF</td>
<td>iret</td>
<td>3 to 9</td>
<td>interrupt return</td>
<td></td>
</tr>
<tr>
<td>2BF0</td>
<td>settimeslice</td>
<td>1</td>
<td>set timeslicing status</td>
<td></td>
</tr>
<tr>
<td>2CF4</td>
<td>intdis</td>
<td>1</td>
<td>interrupt disable</td>
<td></td>
</tr>
<tr>
<td>2CF5</td>
<td>intenb</td>
<td>2</td>
<td>interrupt enable</td>
<td></td>
</tr>
<tr>
<td>2CFD</td>
<td>gintdis</td>
<td>2</td>
<td>global interrupt disable</td>
<td></td>
</tr>
<tr>
<td>2CFE</td>
<td>gintenb</td>
<td>2</td>
<td>global interrupt enable</td>
<td></td>
</tr>
</tbody>
</table>

Table 5.21  Scheduling support instructions

<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>26FE</td>
<td>ldtraph</td>
<td>11</td>
<td>load trap handler</td>
<td>L</td>
</tr>
<tr>
<td>2CF6</td>
<td>ldtrapped</td>
<td>11</td>
<td>load trapped process status</td>
<td>L</td>
</tr>
<tr>
<td>2CFB</td>
<td>sttrapped</td>
<td>11</td>
<td>store trapped process status</td>
<td>S</td>
</tr>
<tr>
<td>26FF</td>
<td>sttraph</td>
<td>11</td>
<td>store trap handler</td>
<td>S</td>
</tr>
<tr>
<td>60F7</td>
<td>trapenb</td>
<td>2</td>
<td>trap enable</td>
<td></td>
</tr>
<tr>
<td>60F6</td>
<td>trapdis</td>
<td>2</td>
<td>trap disable</td>
<td></td>
</tr>
<tr>
<td>60FB</td>
<td>tret</td>
<td>9</td>
<td>trap return</td>
<td></td>
</tr>
</tbody>
</table>

Table 5.22  Trap handler instructions

<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>68FC</td>
<td>ldprodid</td>
<td>1</td>
<td>load product identity</td>
<td></td>
</tr>
<tr>
<td>63F0</td>
<td>nop</td>
<td>1</td>
<td>no operation</td>
<td></td>
</tr>
</tbody>
</table>

Table 5.23  Processor initialization and no operation instructions
<table>
<thead>
<tr>
<th>Memory code</th>
<th>Mnemonic</th>
<th>Processor cycles</th>
<th>Name</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>64FF</td>
<td>clockenb</td>
<td>2</td>
<td>clock enable</td>
<td></td>
</tr>
<tr>
<td>64FE</td>
<td>clockdis</td>
<td>2</td>
<td>clock disable</td>
<td></td>
</tr>
<tr>
<td>64FD</td>
<td>ldclock</td>
<td>1</td>
<td>load clock</td>
<td></td>
</tr>
<tr>
<td>64FC</td>
<td>stclock</td>
<td>2</td>
<td>store clock</td>
<td></td>
</tr>
</tbody>
</table>

Table 5.24  Clock instructions
6 Memory map

The ST20450 processor memory has a 32-bit signed address range. Words are addressed by 30-bit word addresses and a 2-bit byte-selector identifies the bytes in the word. Memory is divided into 4 banks which can each have different memory characteristics and can be used for different purposes. In addition, on-chip peripherals can be accessed via the device access instructions (see Table 5.19).

Various memory locations at the bottom and top of memory are reserved for special system purposes. There is also a default allocation of memory banks to different uses.

6.1 System memory use

The ST20450 has a signed address space where the address ranges from MinInt (#80000000) at the bottom to MaxInt (#7FFFFFFF) at the top. The ST20450 has an area of 16 Kbytes of RAM at the bottom of the address space provided by on chip memory. The bottom of this area is used to store various items of system state. These addresses should not be accessed directly but via the appropriate instructions.

Near the bottom of the address space there is a special address MemStart. Memory above this address is for use by user programs while addresses below it are for private use by the processor and used for subsystem channels and trap handlers. The address of MemStart can be obtained via the ldmemstartval instruction.

6.1.1 Subsystem channels memory

Each DMA channel between the processor and a subsystem is allocated a word of storage below MemStart. This is used by the processor to store information about the state of the channel. This information should not normally be examined directly, although debugging kernels may need to do so.

Boot channels

The subsystem channel which is a link input channel is identified as a ‘boot channel’. When the processor is reset, and is set to boot from link, it waits for boot commands on one of these channels.

6.1.2 Trap handlers memory

The area of memory reserved for trap handlers is broken down hierarchically. Full details on trap handlers is given in see Section 3.6 on page 16.

- Each high/low process priority has a set of trap handlers.
- Each set of trap handlers has a handler for each of the four trap groups (refer to Section 3.6.1).
- Each trap group handler has a trap handler structure and a trapped process structure.
- Each of the structures contains four words, as detailed in Section 3.6.3.

The contents of these addresses can be accessed via ldtraph, sttraph, ldtrapped and sttrapped instructions.
6.2 Boot ROM

When the processor boots from ROM, it jumps to a boot program held in ROM with an entry point 2 bytes from the top of memory at #7FFFFFFE. These 2 bytes are used to encode a negative jump of up to 256 bytes down in the ROM program. For large ROM programs it may then be necessary to encode a longer negative jump to reach the start of the routine.

6.3 Internal peripheral space

On-chip peripherals are mapped to addresses in the top half of memory bank 2 (address range #20000000 to #3FFFFFFF). They can only be accessed by the device access instructions (see Table 5.19). When used with addresses in this range, the device instructions access the on-chip peripherals rather than external memory. For all other addresses the device instructions access memory. Standard load/store instructions to these addresses will access external memory.

This area of memory is allocated to peripherals in 4K blocks, see the following memory map.

<table>
<thead>
<tr>
<th>ADDRESS</th>
<th>USE</th>
</tr>
</thead>
<tbody>
<tr>
<td>MemStart</td>
<td></td>
</tr>
<tr>
<td>#80000140</td>
<td>User code/Data/Stack</td>
</tr>
<tr>
<td>#80000130</td>
<td>Low priority Scheduler trapped process</td>
</tr>
<tr>
<td>#80000120</td>
<td>Low priority Scheduler trap handler</td>
</tr>
<tr>
<td>#80000110</td>
<td>Low priority SystemOperations trapped process</td>
</tr>
<tr>
<td>#80000100</td>
<td>Low priority SystemOperations trap handler</td>
</tr>
<tr>
<td>#800000F0</td>
<td>Low priority Error trapped process</td>
</tr>
<tr>
<td>#800000E0</td>
<td>Low priority Error trap handler</td>
</tr>
<tr>
<td>#800000D0</td>
<td>Low priority Breakpoint trapped process</td>
</tr>
<tr>
<td>#800000C0</td>
<td>Low priority Breakpoint trap handler</td>
</tr>
<tr>
<td>#800000B0</td>
<td>High priority Scheduler trapped process</td>
</tr>
<tr>
<td>#800000A0</td>
<td>High priority Scheduler trap handler</td>
</tr>
<tr>
<td>#80000090</td>
<td>High priority SystemOperations trapped process</td>
</tr>
<tr>
<td>#80000080</td>
<td>High priority SystemOperations trap handler</td>
</tr>
<tr>
<td>#80000070</td>
<td>High priority Error trapped process</td>
</tr>
<tr>
<td>#80000060</td>
<td>High priority Error trap handler</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>ADDRESS</th>
<th>USE</th>
</tr>
</thead>
<tbody>
<tr>
<td>BootEntry</td>
<td></td>
</tr>
<tr>
<td>#7FFFFFFE</td>
<td>Boot entry point</td>
</tr>
<tr>
<td>#40000000</td>
<td>User code/Data/Stack and Boot ROM</td>
</tr>
<tr>
<td>#20004000</td>
<td>Other on-chip peripherals (registers accessed via CPU device accesses)</td>
</tr>
<tr>
<td>#20003000</td>
<td>Diagnostic controller peripheral (registers accessed via CPU device accesses)</td>
</tr>
<tr>
<td>#20002000</td>
<td>EMI controller peripheral (registers accessed via CPU device accesses)</td>
</tr>
<tr>
<td>#20001000</td>
<td>Low-power controller peripheral (registers accessed via CPU device accesses)</td>
</tr>
<tr>
<td>#20000000</td>
<td>Interrupt controller peripheral (registers accessed via CPU device accesses)</td>
</tr>
<tr>
<td>#00000000</td>
<td>External peripherals</td>
</tr>
</tbody>
</table>

Figure 6.1 ST20450 memory map
<table>
<thead>
<tr>
<th>ADDRESS</th>
<th>USE</th>
</tr>
</thead>
<tbody>
<tr>
<td>#80000050</td>
<td>High priority Breakpoint trapped process</td>
</tr>
<tr>
<td>TrapBase</td>
<td>#80000040 High priority Breakpoint trap handler</td>
</tr>
<tr>
<td>#8000003C</td>
<td>RESERVED</td>
</tr>
<tr>
<td>#80000038</td>
<td></td>
</tr>
<tr>
<td>#80000034</td>
<td></td>
</tr>
<tr>
<td>#80000030</td>
<td></td>
</tr>
<tr>
<td>#8000002C</td>
<td></td>
</tr>
<tr>
<td>#80000028</td>
<td></td>
</tr>
<tr>
<td>#80000024</td>
<td></td>
</tr>
<tr>
<td>#80000020</td>
<td>Event channel</td>
</tr>
<tr>
<td>#8000001C</td>
<td>Link3 (boot) input channel</td>
</tr>
<tr>
<td>#80000018</td>
<td>Link2 (boot) input channel</td>
</tr>
<tr>
<td>#80000014</td>
<td>Link1 (boot) input channel</td>
</tr>
<tr>
<td>#80000010</td>
<td>Link0 (boot) input channel</td>
</tr>
<tr>
<td>#8000000C</td>
<td>Link3 output channel</td>
</tr>
<tr>
<td>#80000008</td>
<td>Link2 output channel</td>
</tr>
<tr>
<td>#80000004</td>
<td>Link1 output channel</td>
</tr>
<tr>
<td>MinInt</td>
<td>#80000000 Link0 output channel</td>
</tr>
</tbody>
</table>

Figure 6.1 ST20450 memory map
7 Memory subsystem

The memory system consists of SRAM and an external memory interface (EMI). The specific details on the operation of the EMI are described separately in Chapter 8.

7.1 SRAM

There is an internal memory module of 16 Kbytes of SRAM. The internal SRAM is mapped into the base of the memory space from MinInt (#80000000) extending upwards, as shown in Figure 7.1. This memory can be used to store on-chip data, stack or code for time critical routines.

Where internal memory overlays external memory, internal memory is accessed in preference. An external control (DisableRAM) is provided which can be used to disable internal RAM.

Figure 7.1 SRAM mapping
8 External memory interface

The External Memory Interface (EMI) controls the movement of data between the ST20450 and off-chip memory.

The EMI can access a 4 Gbyte physical address space, and provides sustained transfer rates of up to 100 Mbytes/s for SRAM, and up to 89 Mbytes/s using page-mode DRAM. It is designed to support memory subsystems with minimal (often zero) external support logic.

The interface can be configured for a wide variety of timing and decode functions through configuration registers.

The external address space is partitioned into four banks, with each bank occupying one quarter of the address space (see Figure 8.1). This allows the implementation of mixed memory systems, with support for DRAM, SRAM, EPROM, VRAM and I/O. The timing of each of the four memory banks can be selected separately, with a different device type being placed in each bank with no external hardware support.

![Figure 8.1 Memory allocation](image)

On-chip internal SRAM is located at the bottom of memory. Internal SRAM is internally divided into three regions. The first at the bottom is used for channel storage space, the second region is
reserved for traps and exceptions, the third region is free for program use. The boundary between the second and third region is called MemStart and is the lowest location in memory available for general use.

As the banks are of a fixed size and cover the whole address space, range checking of addresses is not possible. This means that software tools must be aware of the physical external memory capacity (this is possible with the configurer). Also, the current software tools cannot utilize discontinuous memory (for example, 32K SRAM in bank 0 and 4M DRAM in bank 1), therefore if mixed memory types must be placed contiguously in the memory map the division must be decoded and handled off-chip.

Word addressing is used. Support for byte and part-word addressing is provided.

In this chapter a cycle is one processor clock cycle and a phase is one half of the duration of one processor clock cycle.

8.1 Pin functions

The following section describes the functions of the external memory interface pins. Note that a signal name prefixed by not indicates active low.

MemData0-31
The data bus transfers 32, 16 or 8-bit data items depending on the bus width configuration. The least significant bit of the data bus is always MemData0. The most significant bit varies with bus width, MemData31 for 32-bit data items, MemData15 for 16-bit data items, and MemData7 for 8-bit data items.

MemAddr2-31
The address bus may be operated in both multiplexed and non-multiplexed modes. When a bank is configured to contain DRAM, or other multiplexed memory, then the internally generated 32-bit address is multiplexed as row and column addresses through the external address bus.

notMemBE0-3
The ST20450 uses word addressing and four byte-enable strobes are provided. Use of the byte-enable pins depends on the bus width.

- 32-bit wide memory is defined as an array of 4 byte words with MemAddr2-31 selecting a 4 byte word. Each byte of this array is addressable with the byte enable pins notMemBE0-3 selecting a byte within a word.
- 16-bit wide memory is defined as an array of 2 byte words with 31 address bits selecting a 2 byte word and notMemBE0-1 selecting a byte within the word.
- 8-bit wide memory is defined as an array of 1 byte words with 32 address bits selecting a word.

For 16-bit and 8-bit wide memory, the lower order address bits (A1 and A0) are multiplexed onto the unused byte-enable pins to give an address bus 31 or 32-bits wide respectively.

notMemBE0 addresses the least significant byte of a word. Both strobes have the same timing and may be configured to be active on read and or write cycles.

The function of the byte enables notMemBE0-3 for different bank size configurations is given in Table 8.1 below. Note that other bus masters must not drive the same data pins during a write.
One programmable RAS strobe is allocated to each of the four banks which are decoded on chip. If a bank is programmed to contain DRAM, or other multiplexed memory, then the associated \texttt{notMemRAS} pin acts as its RAS strobe by default. For banks which do not contain DRAM the \texttt{notMemRAS} pin is available as a general purpose programmable strobe.

One programmable CAS strobe is allocated to each of the four banks which are decoded on chip. If a bank is programmed to contain DRAM, or other multiplexed memory, then the associated \texttt{notMemCAS} pin acts as its CAS strobe by default. For banks which do not contain DRAM the \texttt{notMemCAS} pin is available as a general purpose programmable strobe.

These additional general purpose programmable strobos (one per bank) may be programmed in the same way as the \texttt{notMemCAS0-3} strobos.

### MemWait

Wait states can be generated by taking \texttt{MemWait} high. \texttt{MemWait} is sampled during \texttt{RASTime} and \texttt{CASTime}. \texttt{MemWait} retains the state of any strobe during the cycle in which \texttt{MemWait} was asserted. \texttt{MemWait} suspends the cycle counter and the strobe generation logic until deasserted. When \texttt{MemWait} is de-asserted cycles continue as programmed by the configuration interface.

### MemReq, MemGranted

Direct memory access (DMA) can be requested at any time by driving the asynchronous \texttt{MemReq} signal high. The address and data buses are tristated after the current memory access or refresh cycle terminates.

Strobes are left inactive during the DMA transfer. If a DMA is active for longer than one programmed refresh interval then external logic is responsible for providing refresh.

The \texttt{MemGranted} signal follows the timing of the bus being tristated and can be used to signal to the device requesting the DMA that it has control of the bus.

### Table 8.1 \texttt{notMemBE0-3} pins

<table>
<thead>
<tr>
<th>\texttt{notMemBE3}</th>
<th>\texttt{notMemBE2}</th>
<th>\texttt{notMemBE1}</th>
<th>\texttt{notMemBE0}</th>
</tr>
</thead>
<tbody>
<tr>
<td>\texttt{notMemBE3} &lt;br&gt; enables \texttt{MemData24-31}</td>
<td>\texttt{notMemBE2} &lt;br&gt; enables \texttt{MemData16-23}</td>
<td>\texttt{notMemBE1} &lt;br&gt; enables \texttt{MemData8-15}</td>
<td>\texttt{notMemBE0} &lt;br&gt; enables \texttt{MemData0-7}</td>
</tr>
<tr>
<td>\texttt{notMemBE3} &lt;br&gt; becomes \texttt{A1}</td>
<td>\texttt{notMemBE2} &lt;br&gt; undefined</td>
<td>\texttt{notMemBE1} &lt;br&gt; enables \texttt{MemData8-15}</td>
<td>\texttt{notMemBE0} &lt;br&gt; enables \texttt{MemData0-7}</td>
</tr>
</tbody>
</table>

\texttt{notMemRAS0-3}

<table>
<thead>
<tr>
<th>\texttt{notMemRAS0-3}</th>
</tr>
</thead>
<tbody>
<tr>
<td>\texttt{notMemRAS0-3} &lt;br&gt; enables \texttt{MemData24-31}</td>
</tr>
</tbody>
</table>

\texttt{notMemCAS0-3}

<table>
<thead>
<tr>
<th>\texttt{notMemCAS0-3}</th>
</tr>
</thead>
<tbody>
<tr>
<td>\texttt{notMemCAS0-3} &lt;br&gt; enables \texttt{MemData16-23}</td>
</tr>
</tbody>
</table>

\texttt{notMemPS0-3}

<table>
<thead>
<tr>
<th>\texttt{notMemPS0-3}</th>
</tr>
</thead>
<tbody>
<tr>
<td>\texttt{notMemPS0-3} &lt;br&gt; enables \texttt{MemData8-15}</td>
</tr>
</tbody>
</table>

| \texttt{notMemPS0-3} <br> enables \texttt{MemData0-7} | \texttt{notMemPS0-3} <br> enables \texttt{MemData0-7} | \texttt{notMemPS0-3} <br> enables \texttt{MemData0-7} | \texttt{notMemPS0-3} <br> enables \texttt{MemData0-7} |
Table 8.2 lists the processor pin state while \textbf{MemGranted} is asserted.

<table>
<thead>
<tr>
<th>MemGranted asserted</th>
</tr>
</thead>
<tbody>
<tr>
<td>Pin name</td>
</tr>
<tr>
<td>MemAddr2-31</td>
</tr>
<tr>
<td>MemData0-31</td>
</tr>
<tr>
<td>notMemBE0-3</td>
</tr>
<tr>
<td>notMemRAS0-3</td>
</tr>
<tr>
<td>notMemCAS0-3</td>
</tr>
<tr>
<td>notMemPS0-3</td>
</tr>
<tr>
<td>notMemRf</td>
</tr>
<tr>
<td>notMemRd</td>
</tr>
<tr>
<td>MemRefPend</td>
</tr>
</tbody>
</table>

Table 8.2 Pin states while \textbf{MemGranted} is asserted

\textbf{MemRefPend}

If any of the four banks are configured to contain DRAM, then the \textbf{MemRefPend} pin indicates to external logic that the programmed refresh interval is complete and requests the external buses in order to perform a refresh cycle.

The \textbf{MemRefPend} signal is held high until external memory is relinquished by the DMA agent. Once \textbf{MemReq} has been taken low, only one refresh transaction will be performed, even if several refresh intervals have elapsed between the assertion of \textbf{MemRefPend} and the removal of \textbf{MemReq}. Refresh transactions will resume once the next refresh interval is complete.

\textbf{MemRefPend} may be configured to signal all pending EMI activity or just pending refresh transactions.

\textbf{notMemRd}

The \textbf{notMemRd} signal indicates that the current cycle is a read cycle. It is asserted low at the beginning of the read cycle and deasserted high at the end of the read cycle.

\textbf{notMemRf}

The \textbf{notMemRf} signal indicates that the current cycle is a refresh cycle. It is asserted low at the beginning of the refresh cycle and deasserted high at the end of the refresh cycle.

\textbf{ProcClkOut}

Reference signal for external bus cycles. \textbf{ProcClkOut} oscillates at the processor clock frequency.

\textbf{BootSrce0-1}

The \textbf{BootSrce0-1} pins determine whether the ST20450 will boot from link or from ROM. When the \textbf{BootSrce0-1} pins are both held low the ST20450 will boot from its link. If either or both pins are high the ST20450 will boot from ROM, as shown in Table 8.3. Boot code is run from a slow external ROM placed in bank 3 (at the top of memory). The \textbf{BootSrce0-1} pins also encode the size of bank 3. This overrides the value in the configuration registers for the \textbf{PortSize} for bank 3.

When booting from the link, the port size of bank 3 must be configured as with any other EMI parameter, otherwise the \textbf{PortSize} field in the \textbf{ConfigDataField1} register for bank 3 (see Section 8.3) will be overridden by the value on the \textbf{BootSrce0-1} pins.
If the ST20450 is set to boot from link, the bootstrap must execute from internal memory until the EMI has been configured. If this is not possible then the EMI must be completely configured using poke commands down a link before loading the bootstrap into external memory and executing it.

<table>
<thead>
<tr>
<th>BootSrce1:0</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0:0</td>
<td>Boot from link. The ST20450 loads bootstrap down the link and executes from MemStart.</td>
</tr>
<tr>
<td>0:1</td>
<td>Boot from ROM. Port size of bank 3 hardwired to 32-bits.</td>
</tr>
<tr>
<td>1:0</td>
<td>Boot from ROM. Port size of bank 3 hardwired to 16-bits.</td>
</tr>
<tr>
<td>1:1</td>
<td>Boot from ROM. Port size of bank 3 hardwired to 8-bits.</td>
</tr>
</tbody>
</table>

Table 8.3 BootSrce0-1 pins

DisableRAM

Internal SRAM can be disabled by setting the DisableRAM pin high, enabling systems to operate in external memory only.

When the DisableRAM pin is low, i.e. internal SRAM is active, all addresses between MinInt and MinInt+16K are directed to internal SRAM and external memory at these addresses is never accessed.

8.2 External bus cycles

The external memory interface is designed to provide efficient support for dynamic memory without compromising support for other devices, such as static memory and IO devices. This flexibility is provided by allowing the required waveforms to be programmed via configuration registers (see Section 8.3).

Memory is byte addressed, with words aligned on four-byte boundaries for 32-bit devices and on two-byte boundaries for 16-bit devices.

During read cycles byte level addressing is performed internally by the ST20450. The EMI can read bytes, half-words or words. It always reads the size of the bank.

During read or write cycles the ST20450 uses the notMemBE0-3 strobes to perform addressing of bytes. If a particular byte is not to be written then the corresponding data outputs are tristated.

Writes can be less than the size of the bank.

The internally generated address is indicated on pins MemAddr2-31, however the low order address bits A0 and A1 have different functions depending on the size of the external data bus, see Table 8.1. The least significant bit of the data bus is always MemData0. The most significant bit can be adjusted dynamically to suit the required external bus size.

Note that data pins which are not used during a write access are tristated, for example, for an 8-bit bus pins MemData8-31 are tristated.

A generic memory interface cycle consists of a number of defined periods, or times, as shown in Figure 8.2. This generic memory cycle uses DRAM terminology to clarify the use of the interface in the most complex situations, but can be programmed to provide waveforms for a wide range of other device types. The timing of each of the four memory banks can be programmed separately, with a different device type being placed in each bank with no external hardware support.

The RASTime and CASTime are consecutive. The CASTime can be followed by concurrent Precharge and BusRelease times. Thus, for DRAM, the times are used for RAS, CAS, and
precharge respectively. For non-multiplexed addressed memory the RASTime can be programmed to be zero.

If the RASTime is programmed to be non-zero, and page-mode memory is programmed in a bank, the RASTime will only occur if consecutive accesses are not in the same page. The RASTime will not commence until the PrechargeTime for a previous access to the same bank has completed. During the RASTime a transition can be programmed on the RAS and programmable strobes, but not on the CAS or byte enable strobes.

During the CASTime the programmable strobes and byte-enable strobes are active. The address is output on the address bus without being shifted. Write data is valid during CASTime. Read data is latched into the interface at the end of CASTime.

The PrechargeTime and BusReleaseTime commence concurrently at the end of the CASTime. A PrechargeTime will occur to the current bank if:

- the next access is to the same bank but to a different row address.
- the next cycle is to a different bank.

The BusReleaseTime runs concurrently with the PrechargeTime and will occur if:

- the current cycle is a read and the next cycle is a write.
- the current cycle is a read and the next cycle is a read to a different bank.

The BusReleaseTime is provided to allow slow devices to float to a high impedance state.
8.2.1 Refresh

Configuration fields are provided which specify the banks which require refreshing and the interval between successive refreshes.

The EMI ensures that notMemCAS and notMemRAS are both high for the required time before every refresh cycle by inserting a PrechargeTime in the last bank being accessed and ensuring all PrechargeTimes are complete.

The behaviour of the notMemCAS strobes during a refresh cycle is dependent on the programming of the byte mode configuration field.

The notMemCAS strobe is taken low at the beginning of the refresh time. The position of the RAS falling edge (RASedge) and the time before notMemRAS and notMemCAS can be taken high again (RefreshTime) are programmable. Each of these actions occurs in sequence for each bank. A cycle is inserted between each bank in order to spread current peaks. If no DRAM has been programmed for a bank then no transitions occur on the RAS or CAS strobes.

Note, no refreshes take place unless a DRAMinitialize command in the ConfigCommand register (see Section 8.3.1 on page 51) is performed.

![Figure 8.3 Refresh](image)
8.2.2 Wait

MemWait is provided so that external cycles can be extended to enable variable access times (for example, shared memory access). MemWait is sampled on a rising clock edge before being passed into the EMI. It is only effective when the EMI is in the RAS or CAS times and has the effect of holding the RAS and CAS counter values for the duration of the cycles in which it was sampled high. Any strobe transitions occurring on the sampling edge or the falling edge immediately after will not be inhibited, but transitions on the rising and falling edges of the cycle after will not occur. Figure 8.4 and Figure 8.5 show the extension of the external memory cycle and the delaying of strobe transitions.

---

**Figure 8.4 Strobe activity without MemWait**

---

**Figure 8.5 Strobe activity with MemWait**
8.3 EMI Configuration

The EMI configuration is held in memory-mapped registers. The function of the registers is to eliminate external decode and timing logic. Each EMI bank has several parameters which can be configured. The parameters define the structure of the external address space and how it is allocated to the four banks and the timing of the strobe edges for the four banks.

The EMI has four banks of four 32-bit configuration registers to set up the four EMI banks. In addition there is another register to set the pad drive strength. For safe configuration each of the four banks must be configured in a single operation in cooperation with the EMI control logic. To enable this, there is a bank of four temporary registers (ConfigDataField0-3) inside the EMI configuration logic which can be filled with an entire bank before being transferred in a single operation to the EMI. The data is only transferred when the EMI is able to receive it. This single operation is the WriteConfig command in the ConfigCommand register. A typical configuration sequence is to program each individual temporary register (ConfigDataField0-3) followed by a write to the WriteConfig address to transfer the data to the EMI.

The configuration logic contains six registers which are used to transfer data to and from the EMI configuration registers, as listed in Table 8.4. The registers can be examined and set by the devlw (device load word) and devsw (device store word) instructions. Note, they can not be accessed using memory instructions. These registers may be accessed independently of EMI activity, unless the configuration controller is processing a previous command, for example a WriteConfig.

The base address for the EMI configuration registers are given in the ST20450 memory map, see Figure 6.1 on page 39.

Note: The EMI configuration registers can not be accessed directly, they can only be accessed via the temporary registers in the configuration logic.
### Table 8.4 EMI configuration register addresses

<table>
<thead>
<tr>
<th>Register</th>
<th>Address</th>
<th>Data byte</th>
<th>Read/Write</th>
<th>Command</th>
</tr>
</thead>
<tbody>
<tr>
<td>ConfigCommand</td>
<td>EMI base address + #10</td>
<td>#00</td>
<td>Write</td>
<td>ReadConfig bank 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>#04</td>
<td>Write</td>
<td>ReadConfig bank 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>#08</td>
<td>Write</td>
<td>ReadConfig bank 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>#0C</td>
<td>Write</td>
<td>ReadConfig bank 3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>#10</td>
<td>Write</td>
<td>ReadConfig PadDriveReg</td>
</tr>
<tr>
<td></td>
<td></td>
<td>#20</td>
<td>Write</td>
<td>DRAMinitialize</td>
</tr>
<tr>
<td></td>
<td></td>
<td>#40</td>
<td>Write</td>
<td>WriteConfig bank 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>#44</td>
<td>Write</td>
<td>WriteConfig bank 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>#48</td>
<td>Write</td>
<td>WriteConfig bank 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>#4C</td>
<td>Write</td>
<td>WriteConfig bank 3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>#50</td>
<td>Write</td>
<td>WriteConfig PadDriveReg</td>
</tr>
<tr>
<td></td>
<td></td>
<td>#60</td>
<td>Write</td>
<td>LockConfig</td>
</tr>
<tr>
<td>ConfigDataField0</td>
<td>EMI base address + #00</td>
<td>-</td>
<td>Read/Write</td>
<td></td>
</tr>
<tr>
<td>ConfigDataField1</td>
<td>EMI base address + #04</td>
<td>-</td>
<td>Read/Write</td>
<td></td>
</tr>
<tr>
<td>ConfigDataField2</td>
<td>EMI base address + #08</td>
<td>-</td>
<td>Read/Write</td>
<td></td>
</tr>
<tr>
<td>ConfigDataField3</td>
<td>EMI base address + #0C</td>
<td>-</td>
<td>Read/Write</td>
<td></td>
</tr>
<tr>
<td>ConfigStatus</td>
<td>EMI base address + #20</td>
<td>-</td>
<td>Read</td>
<td></td>
</tr>
</tbody>
</table>

### 8.3.1 ConfigCommand register

The **ConfigCommand** register is a write only register. When a write is performed to this register, plus the associated data byte, various operations are performed as detailed in Table 8.5.

To avoid further EMI activity occurring between successive update requests, all parameters for a bank must be changed in a single operation by performing a **WriteConfig** command.

The timing information for DRAM refresh is distributed amongst access timing information in the **ConfigDataField0-3** registers. DRAM is initialized by performing a **DRAMinitialize** command. The **DRAMinitialize** command also enables refreshes to take place. If no **DRAMinitialize** command is performed no refreshes will take place.

Note, the **DRAMinitialize** command should only be written when there is DRAM in the system.
### 8.3.2 ConfigStatus register

The **ConfigStatus** register is a read only register and contains information on whether the **ConfigDataField0-3** registers have been write locked and shows which EMI banks have been written.

<table>
<thead>
<tr>
<th>Bit</th>
<th>Bit field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>WrittenBank0</td>
<td>Bank 0 has been configured by the WriteConfig command.</td>
</tr>
<tr>
<td>1</td>
<td>WrittenBank1</td>
<td>Bank 1 has been configured by the WriteConfig command.</td>
</tr>
<tr>
<td>2</td>
<td>WrittenBank2</td>
<td>Bank 2 has been configured by the WriteConfig command.</td>
</tr>
<tr>
<td>3</td>
<td>WrittenBank3</td>
<td>Bank 3 has been configured by the WriteConfig command.</td>
</tr>
<tr>
<td>4</td>
<td>WrittenPadDriveReg</td>
<td>The PadDrive register has been written by the WriteConfig command.</td>
</tr>
<tr>
<td>5</td>
<td>WriteLock</td>
<td>ConfigDataField0-3 registers are write locked.</td>
</tr>
<tr>
<td>31:5</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table 8.6 **ConfigStatus** register

### 8.3.3 ConfigDataField0-3 registers

The bit format and functionality of the **ConfigDataField0-3** registers for transfers to/from each of the register banks are described in the following sections.

The **ConfigDataField0-3** registers are grouped, with one group of four registers containing all the information necessary to program an external bank. The format of bits in the registers depends on which EMI bank is being configured, see Figure 8.6.
**Figure 8.6** ConfigDataField0-3 registers

### ConfigDataField0 - banks 0, 1, 2 and 3

|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

### ConfigDataField1

**bank 0**

|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**bank 1**

|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**bank 2**

|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**bank 3**

|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

### ConfigDataField2 - banks 0, 1, 2 and 3

|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

### ConfigDataField3 - banks 0, 1, 2 and 3

|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
8.3.4 Format of the data registers for transfers to/from register bank 0

This section gives the format of the ConfigDataField0-3 registers for transfers to/from register bank 0.

ConfigDataField0 format for transfers to/from register bank 0

The ConfigDataField0 register is a 32 bit register which can be set to read only via the ConfigCommand register.

The RASbits31:2 field is a 30 bit address mask which defines which address bits are compared to determine whether a page hit has occurred. Generally it will be loaded with a field of 1’s padded out by 0’s.

For example, if bank 0 contained 4 Mbyte DRAM, organized as four 4 Mbit x 8 devices for a 32-bit wide interface, there would be 1 MWords of DRAM, with 1024 pages each containing 1024 words. It is necessary for RASbits31:30 to be set to ‘11’ to enable bank switches to be detected. The RASbits field for bank 0 would be:

RASbits31:2  11111111111111111111000000000000

For example, for a 16-bit wide interface, the RASbits field for bank 0 would be:

RASbits31:2  11111111111111111111100000000000

<table>
<thead>
<tr>
<th>ConfigDataField0</th>
<th>EMI base address + #00</th>
<th>Read/Write</th>
</tr>
</thead>
<tbody>
<tr>
<td>Bit</td>
<td>Bit field</td>
<td>Function</td>
</tr>
<tr>
<td>1</td>
<td>PageMode</td>
<td>Page mode valid</td>
</tr>
<tr>
<td>31:2</td>
<td>RASbits31:2</td>
<td>Defines the RAS bits in the address which should be compared to the last access to the same bank to determine whether a page hit has occurred.</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
<td></td>
</tr>
</tbody>
</table>

Table 8.7 ConfigDataField0 format for transfers to/from register bank 0
ConfigDataField1 format for transfers to/from register bank 0

The **ConfigDataField1** register is a 32 bit register which can be set to read only via the **ConfigCommand** register.

<table>
<thead>
<tr>
<th>Bit</th>
<th>Bit field</th>
<th>Function</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>1:0</td>
<td>PortSize</td>
<td>Bit width of the bank (8,16, or 32-bits).</td>
<td></td>
</tr>
<tr>
<td></td>
<td>PortSize1:0</td>
<td><strong>Bank width</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td>00</td>
<td>Invalid</td>
<td></td>
</tr>
<tr>
<td></td>
<td>01</td>
<td>32-bits</td>
<td></td>
</tr>
<tr>
<td></td>
<td>10</td>
<td>16-bits</td>
<td></td>
</tr>
<tr>
<td></td>
<td>11</td>
<td>8-bits</td>
<td></td>
</tr>
<tr>
<td>6:2</td>
<td>ShiftAmount</td>
<td>Defines how many bits to shift the bank address in order to convert it to</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>a row address for multiplexed-addressed memory during RAStime. It is</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>irrelevant at all other times.</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>MemWaitEnable</td>
<td>Enables the <strong>MemWait</strong> pin.</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>RAStimeEqZero</td>
<td>No RAS cycle will occur. The bank is considered to be an SRAM bank.</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>PrechargeTimeEqZero</td>
<td>No Precharge Time will occur.</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>RefreshTime0</td>
<td>Refresh time 0. The refresh time is a 4-bit value. <strong>RefreshTime</strong> bits 1,</td>
<td>Cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td>2 and 3 are specified in <strong>ConfigDataField1</strong> for transfers to/from register</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>banks 1, 2 and 3 respectively.</td>
<td></td>
</tr>
<tr>
<td>15:12</td>
<td>PrechargeTime</td>
<td>Duration of precharge time.</td>
<td>Cycles</td>
</tr>
<tr>
<td>17</td>
<td>CyclePendingMask</td>
<td>Masks the memory access cycle. Determines whether <strong>MemRefPend</strong> indicates</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>pending refresh cycles or pending memory access during DMA.</td>
<td></td>
</tr>
<tr>
<td>21:18</td>
<td>DRAM3:0</td>
<td>Defines which banks require refresh.</td>
<td>Cycles</td>
</tr>
<tr>
<td>23:22</td>
<td>RAStime</td>
<td>Duration of RAS sub-cycle.</td>
<td>Cycles</td>
</tr>
<tr>
<td>31:28</td>
<td>CASTime</td>
<td>Duration of CAS sub-cycle.</td>
<td>Cycles</td>
</tr>
<tr>
<td>16, 7</td>
<td></td>
<td>Reserved</td>
<td></td>
</tr>
</tbody>
</table>

Table 8.8 **ConfigDataField1** format for transfers to/from register bank 0
ConfigDataField2 format for transfers to/from register bank 0

The ConfigDataField2 register is a 32 bit register which can be set to read only via the ConfigCommand register.

<table>
<thead>
<tr>
<th>Bit</th>
<th>Bit field</th>
<th>EMI base address + #08</th>
<th>Function</th>
<th>Read/Write</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>1:0</td>
<td>BEe1active</td>
<td></td>
<td>Cycle type in which falling (E1) edge of notMemBE is active.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>BEe1LSB</td>
<td></td>
<td>Specifies the phase when the falling (E1) edge of notMemBE will occur.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>DataDriveDelay0</td>
<td></td>
<td>This is a 2-bit value (DataDriveDelay1 is in bit 7). It is the drive delay of the data bus, as follows:</td>
<td></td>
<td>Phases</td>
</tr>
<tr>
<td></td>
<td>DataDriveDelay1:0</td>
<td></td>
<td>Drive delay of data bus</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>00</td>
<td></td>
<td>0 phases</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>01</td>
<td></td>
<td>1 phase</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>10</td>
<td></td>
<td>2 phases</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>11</td>
<td></td>
<td>3 phases</td>
<td></td>
<td></td>
</tr>
<tr>
<td>5:4</td>
<td>BEe2active</td>
<td></td>
<td>Cycle type in which notMemBE rising (E2) edge is active.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>BEe2LSB</td>
<td></td>
<td>Specifies the phase when the rising (E2) edge of notMemBE will occur.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>DataDriveDelay1</td>
<td></td>
<td>This is a 2-bit value (DataDriveDelay0 is in bit 3). It is the drive delay of the data bus.</td>
<td></td>
<td>Phases</td>
</tr>
<tr>
<td></td>
<td>9:8</td>
<td></td>
<td>DataDriveDelay1:0</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>00</td>
<td></td>
<td>0 phases</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>01</td>
<td></td>
<td>1 phase</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>10</td>
<td></td>
<td>2 phases</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>11</td>
<td></td>
<td>3 phases</td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table 8.9 ConfigDataField2 format for transfers to/from register bank 0

Each of the strobes (notMemRAS, notMemCAS, notMemPS, notMemBE) edges may be configured to be active during reads and/or writes, or to be inactive. The coding of the active bits is given in Table 8.10.
ConfigDataField3 format for transfers to/from register bank 0

The **ConfigDataField3** register is a 32 bit register which can be set to read only via the **ConfigCommand** register.

### Active bit settings

<table>
<thead>
<tr>
<th>Active bit settings</th>
<th>Strobe activity</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>Inactive</td>
</tr>
<tr>
<td>01</td>
<td>Active during read only</td>
</tr>
<tr>
<td>10</td>
<td>Active during write only</td>
</tr>
<tr>
<td>11</td>
<td>Active during read and write</td>
</tr>
</tbody>
</table>

Table 8.10  Active bit settings

#### 8.3.5 Format of the data registers for transfers to/from register bank 1

This section gives the format of the **ConfigDataField0-3** registers for transfers to/from register bank 1.

### ConfigDataField0/2/3 format for transfers to/from register bank 1

The **ConfigDataField0**, **ConfigDataField2** and **ConfigDataField3** registers have the same format for transfers to/from register bank 1 as those given for transfers to/from register bank 0, see Table 8.7, Table 8.9 and Table 8.11 in Section 8.3.4.
ConfigDataField1 format for transfers to/from register bank 1

This register contains refresh information.

<table>
<thead>
<tr>
<th>Bit</th>
<th>Bit field</th>
<th>Function</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>1:0</td>
<td>PortSize</td>
<td>Bit width of the bank (8, 16, or 32-bits).</td>
<td></td>
</tr>
<tr>
<td></td>
<td>PortSize:0</td>
<td>Bank width</td>
<td></td>
</tr>
<tr>
<td></td>
<td>00</td>
<td>Invalid</td>
<td></td>
</tr>
<tr>
<td></td>
<td>01</td>
<td>32-bits</td>
<td></td>
</tr>
<tr>
<td></td>
<td>10</td>
<td>16-bits</td>
<td></td>
</tr>
<tr>
<td></td>
<td>11</td>
<td>8-bits</td>
<td></td>
</tr>
<tr>
<td>6:2</td>
<td>ShiftAmount</td>
<td>Defines how many bits to shift the bank address in order to convert it</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>to a row address for multiplexed-addressed memory during RAS-time.</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>It is irrelevant at all other times.</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>MemWaitEnable</td>
<td>Enables the MemWait pin.</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>RAStimeEqZero</td>
<td>No RAS cycle will occur. The bank is considered to be an SRAM bank.</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>PrechargeTimeEqZero</td>
<td>No Precharge Time will occur.</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>RefreshTime1</td>
<td>Refresh time 1. The refresh time is a 4-bit value. RefreshTime bits 0,</td>
<td>Cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td>2 and 3 are specified in ConfigDataField1 for transfers to/from register</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>banks 0, 2 and 3 respectively.</td>
<td></td>
</tr>
<tr>
<td>15:12</td>
<td>PrechargeTime</td>
<td>Duration of precharge time.</td>
<td>Cycles</td>
</tr>
<tr>
<td>21:17</td>
<td>RefreshRASedgeTime</td>
<td>Refresh RAS falling edge.</td>
<td>Phases</td>
</tr>
<tr>
<td>23:22</td>
<td>RAStime</td>
<td>Duration of RAS sub-cycle.</td>
<td>Cycles</td>
</tr>
<tr>
<td>31:28</td>
<td>CASTime</td>
<td>Duration of CAS sub-cycle.</td>
<td>Cycles</td>
</tr>
<tr>
<td>16, 7</td>
<td>Reserved</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table 8.12  ConfigDataField1 format for transfers to/from register bank 1

8.3.6 Format of the data registers for transfers to/from register bank 2

This section gives the format of the ConfigDataField0-3 registers for transfers to/from register bank 2.

ConfigDataField0/2/3 format for transfers to/from register bank 2

The ConfigDataField0, ConfigDataField2 and ConfigDataField3 registers have the same format for transfers to/from register bank 2 as those given for transfers to/from register bank 0, see tables 8.7, 8.9 and 8.11 in Section 8.3.4 on page 54.

ConfigDataField1 format for transfers to/from register bank 2

This register contains refresh information.

The 12-bit refresh interval is spread across two register fields, see Table 8.14.
### Table 8.13 ConfigDataField1 format for transfers to/from register bank 2

<table>
<thead>
<tr>
<th>Bit</th>
<th>Bit field</th>
<th>Function</th>
<th>Read/Write</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>1:0</td>
<td>PortSize</td>
<td>Bit width of the bank (8/16/32-bits).</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td><strong>PortSize1:0</strong> <strong>Bank width</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>00 Invalid</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>01 32-bits</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>10 16-bits</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>11 8-bits</td>
<td></td>
<td></td>
</tr>
<tr>
<td>6:2</td>
<td>ShiftAmount</td>
<td>Defines how many bits to shift the bank address in</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>order to convert it to a row address for</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>multiplexed-addressed memory during RAStime. It is</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>irrelevant at all other times.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>BusRelMax0</td>
<td>This is a 2-bit value (BusRelMax1 is bit 7 of</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>ConfigDataField1 for bank 3, refer Table 8.14)</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>which encodes a pointer to the EMI bank with the</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>greatest BusRelease time. This BusRelease time will</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>be inserted when the EMI is coming out of a DMA</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>transaction. The encodings are as follows:</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td><strong>BusRelMax1:0</strong> <strong>Greatest BusRelease time</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>00 Bank 0</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>01 Bank 1</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>10 Bank 2</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>11 Bank 3</td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>MemWaitEnable</td>
<td>Enables the MemWait pin.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>RAStimeEqZero</td>
<td>No RAS cycle will occur. The bank is</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>considered to be an SRAM bank.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>PrechargeTimeEqZero</td>
<td>No Precharge Time will occur.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>RefreshTime2</td>
<td>Refresh time 2. The refresh time is a 4-bit value.</td>
<td></td>
<td>Cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td>RefreshTime bits 0, 1 and 3 are specified in ConfigDataField1 for transfers to/from register banks 0, 1 and 3 respectively.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>15:12</td>
<td>PrechargeTime</td>
<td>Duration of precharge time.</td>
<td></td>
<td>Cycles</td>
</tr>
<tr>
<td>21:16</td>
<td>RefreshInterval5:0</td>
<td>This is a 12-bit value (RefreshInterval11:6 is</td>
<td></td>
<td>Cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td>bits 21:16 of ConfigDataField1 for bank 3, refer</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>Table 8.14) which defines the DRAM refresh interval</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>between successive refreshes.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>23:22</td>
<td>RAStime</td>
<td>Duration of RAS sub-cycle.</td>
<td></td>
<td>Cycles</td>
</tr>
<tr>
<td>31:28</td>
<td>CASStime</td>
<td>Duration of CAS sub-cycle.</td>
<td></td>
<td>Cycles</td>
</tr>
</tbody>
</table>

#### 8.3.7 Format of the data registers for transfers to/from register bank 3

This section gives the format of the ConfigDataField0-3 registers for transfers to/from register bank 3.

### ConfigDataField0/2/3 format for transfers to/from register bank 3

The ConfigDataField0, ConfigDataField2 and ConfigDataField3 registers have the same format for transfers to/from register bank 3 as those given for transfers to/from register bank 0, see Table 8.7, Table 8.9 and Table 8.11 in Section 8.3.4.
ConfigDataField1 format for transfers to/from register bank 3

This register contains refresh information. The 12-bit refresh interval value is spread across two register fields.

<table>
<thead>
<tr>
<th>ConfigDataField1</th>
<th>EMI base address + #04</th>
<th>Read/Write</th>
<th>Bit</th>
<th>Bit field</th>
<th>Function</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td>1:0</td>
<td>PortSize</td>
<td>Bit width of the bank (8, 16, or 32-bits).</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>PortSize1:0</td>
<td>Bank width</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00</td>
<td>Invalid</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>01</td>
<td>32-bits</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>10</td>
<td>16-bits</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>11</td>
<td>8-bits</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>6:2</td>
<td>ShiftAmount</td>
<td>Defines how many bits to shift the bank address in order to convert it to a row address for multiplexed-addressed memory during RAStime. It is irrelevant at all other times.</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>7</td>
<td>BusRelMax1</td>
<td>This is a 2-bit value (BusRelMax0 is bit 7 of ConfigDataField1 for bank 2, refer Table 8.13) which encodes a pointer to the EMI bank with the greatest BusRelease time. This BusRelease time will be inserted when the EMI is coming out of a DMA transaction. The encodings are as follows:</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BusRelMax1:0</td>
<td>Greatest BusRelease time</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00</td>
<td>Bank 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>01</td>
<td>Bank 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>10</td>
<td>Bank 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>11</td>
<td>Bank 3</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>8</td>
<td>MemWaitEnable</td>
<td>Enables the MemWait pin.</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>9</td>
<td>RAStimeEqZero</td>
<td>No RAS cycle will occur. The bank is considered to be an SRAM bank.</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>10</td>
<td>PrechargeTimeEqZero</td>
<td>No Precharge Time will occur.</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>11</td>
<td>RefreshTime3</td>
<td>Refresh time 3. The refresh time is a 4-bit value. RefreshTime bits 0, 1 and 2 are specified in ConfigDataField1 for transfers to/from register banks 0, 1 and 2 respectively.</td>
<td>Cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>15:12</td>
<td>PrechargeTime</td>
<td>Duration of precharge time.</td>
<td>Cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>21:16</td>
<td>RefreshInterval11:6</td>
<td>This is a 12-bit value (RefreshInterval5:0 is bits 21:16 of ConfigDataField1 for bank 2, refer Table 8.13) which defines the DRAM refresh interval between successive refreshes.</td>
<td>Cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>23:22</td>
<td>RAStime</td>
<td>Duration of RAS sub-cycle.</td>
<td>Cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>31:28</td>
<td>CASTime</td>
<td>Duration of CAS sub-cycle.</td>
<td>Cycles</td>
</tr>
</tbody>
</table>

Table 8.14 ConfigDataField1 format for transfers to/from register bank 3
8.3.8 Format of the data registers for transfers to/from PadDrive register

This final group of registers consists of just one register. The ConfigDataField0-2 registers are reserved. The ConfigDataField3 register is used for the pad drive strength (PadDrive) register.

This register sets the drive strength of the EMI pads. Once locked the strength is static. Each of the address, data and strobe pads has four possible drive strengths which may be configured as given in Table 8.15.

<table>
<thead>
<tr>
<th>Drive bit settings</th>
<th>Drive strength level</th>
<th>Drive strength</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>level 0</td>
<td>Weakest</td>
</tr>
<tr>
<td>01</td>
<td>level 1</td>
<td>↓</td>
</tr>
<tr>
<td>10</td>
<td>level 2</td>
<td>↓</td>
</tr>
<tr>
<td>11</td>
<td>level 3</td>
<td>Strongest</td>
</tr>
</tbody>
</table>

Table 8.15 Drive bit settings

The PadDrive register has fields which apply to groups of pads so that the edge rates may be tuned to reduce electrical noise or optimize speed. Also the ProcClkOut pin can be disabled in order to reduce power, this is the default on reset.

<table>
<thead>
<tr>
<th>ConfigDataField3</th>
<th>EMI base address + #0C</th>
<th>Read/Write</th>
</tr>
</thead>
<tbody>
<tr>
<td>Bit</td>
<td>Bit field</td>
<td>Function</td>
</tr>
<tr>
<td>1:0</td>
<td>RCP0</td>
<td>Drive strength of pads notMemRAS0, notMemCAS0, notMemPS0</td>
</tr>
<tr>
<td>3:2</td>
<td>RCP1</td>
<td>Drive strength of pads notMemRAS1, notMemCAS1, notMemPS1</td>
</tr>
<tr>
<td>5:4</td>
<td>RCP2</td>
<td>Drive strength of pads notMemRAS2, notMemCAS2, notMemPS2</td>
</tr>
<tr>
<td>7:6</td>
<td>RCP3</td>
<td>Drive strength of pads notMemRAS3, notMemCAS3, notMemPS3</td>
</tr>
<tr>
<td>9:8</td>
<td>BE1</td>
<td>Drive strength of pads notMemBE1</td>
</tr>
<tr>
<td>11:10</td>
<td>BE2</td>
<td>Drive strength of pads notMemBE2</td>
</tr>
<tr>
<td>13:12</td>
<td>A2-8</td>
<td>Drive strength of pads MemAddr2-8, notMemBE0, notMemBE3</td>
</tr>
<tr>
<td>15:14</td>
<td>A9-12</td>
<td>Drive strength of pads MemAddr9-12</td>
</tr>
<tr>
<td>17:16</td>
<td>A13-16</td>
<td>Drive strength of pads MemAddr13-16</td>
</tr>
<tr>
<td>19:18</td>
<td>A17-20</td>
<td>Drive strength of pads MemAddr17-20</td>
</tr>
<tr>
<td>23:22</td>
<td>A25-31</td>
<td>Drive strength of pads MemAddr25-31</td>
</tr>
<tr>
<td>25:24</td>
<td>D0-7</td>
<td>Drive strength of pads MemData0-7</td>
</tr>
<tr>
<td>27:26</td>
<td>D8-15</td>
<td>Drive strength of pads MemData8-15</td>
</tr>
<tr>
<td>29:28</td>
<td>D16-31</td>
<td>Drive strength of pads MemData16-31</td>
</tr>
<tr>
<td>31</td>
<td>ProcClkEnable</td>
<td>When 1, ProcClkOut pin enabled. When 0 (default state on reset), the ProcClkOut pin is disabled, thus reducing power.</td>
</tr>
<tr>
<td>30</td>
<td>Reserved</td>
<td></td>
</tr>
</tbody>
</table>

Table 8.16 ConfigDataField3 format for transfers to/from PadDrive register
8.4 EMI initialization

8.4.1 Reset
When the EMI is reset, the configuration register file loads a default set of parameters suitable for running boot code from a slow external ROM placed in bank 3 (at the top of memory). The refresh interval is reset to zero and no refresh requests are generated until this parameter is changed and the DRAMinitialize command is issued to the configuration logic.

The WriteLock bit in the ConfigStatus register is cleared to enable new parameters to be configured by software.

8.4.2 Bootstrap
When external reset is removed, the ST20450 will start to execute bootstrap code from the area of memory determined by the setting of the BootSrce0-1 pins (see Table 8.3 on page 46).

If the ST20450 is set to boot from a link, the bootstrap must execute from internal memory until the EMI has been configured. If this is not possible, the EMI must be completely configured using poke operations (see Section 9.2.3 on page 65) down the link before loading the bootstrap into external memory and executing it.

8.4.3 Initializing DRAM banks
The timing information for DRAM refresh is spread over the configuration registers (ConfigDataField0-3). DRAM initialization is performed by an explicit command (DRAMinitialize command in the ConfigCommand register) once the configuration is loaded. This command causes 8 consecutive refresh transactions to occur.

Default configuration
The default configuration is loaded into all four banks on reset. The parameters shown in Table 8.18 are also set in the configuration registers.

![Diagram of default access timing]

Table 8.17 Timing of default access
<table>
<thead>
<tr>
<th>Parameter</th>
<th>Default value</th>
</tr>
</thead>
<tbody>
<tr>
<td>RASbits31:2</td>
<td>#0 (all banks)</td>
</tr>
<tr>
<td>PageMode</td>
<td>Cleared (all banks)</td>
</tr>
<tr>
<td>PortSize</td>
<td>Value on BootSrce0-1 pin</td>
</tr>
<tr>
<td>ShiftAmount</td>
<td>0 (all banks)</td>
</tr>
<tr>
<td>BusReleaseMax1:0</td>
<td>3</td>
</tr>
<tr>
<td>MemWaitEnable</td>
<td>Set (all banks)</td>
</tr>
<tr>
<td>RAStimeEqZero</td>
<td>Set (all banks)</td>
</tr>
<tr>
<td>PrechargeTimeEqZero</td>
<td>Set (all banks)</td>
</tr>
<tr>
<td>RefreshTime0,1,2,3</td>
<td>Cleared</td>
</tr>
<tr>
<td>PrechargeTime</td>
<td>0 (all banks)</td>
</tr>
<tr>
<td>CyclePendingMask</td>
<td>Cleared</td>
</tr>
<tr>
<td>DRAM3:0</td>
<td>All cleared</td>
</tr>
<tr>
<td>RefreshRASedgeTime</td>
<td>0</td>
</tr>
<tr>
<td>RefreshInterval</td>
<td>0</td>
</tr>
<tr>
<td>RAStime</td>
<td>0 (all banks)</td>
</tr>
<tr>
<td>BusReleaseTime</td>
<td>3 cycles (all banks)</td>
</tr>
<tr>
<td>CAStime</td>
<td>12 cycles (all banks)</td>
</tr>
<tr>
<td>RAS, BE strobes</td>
<td>Inactive (all banks)</td>
</tr>
<tr>
<td>CAS, PS e1 and e2 active</td>
<td>Only on reads (all banks)</td>
</tr>
<tr>
<td>CASE1 time</td>
<td>2 phases</td>
</tr>
<tr>
<td>CASE2 time</td>
<td>24 phases</td>
</tr>
<tr>
<td>PSE1 time</td>
<td>0 phases</td>
</tr>
<tr>
<td>PSE2 time</td>
<td>24 phases</td>
</tr>
<tr>
<td>DataDriveDelay1:0</td>
<td>2 phases (all banks)</td>
</tr>
<tr>
<td>PadDriveStrength</td>
<td>All 0, weakest drive strength</td>
</tr>
<tr>
<td>ProcClkEnable</td>
<td>ProcClkOut pin disabled</td>
</tr>
</tbody>
</table>

Table 8.18 Default parameters
9 System services

The system services module includes the control system, the PLL, test access port and power control. System services include all the necessary logic to initialize and sustain operation of the device and also includes error handling and analysis facilities.

9.1 Reset, initialization and debug

The ST20450 is controlled by a notRST pin which is a global power-on-reset. The CPU can also be controlled by CPUReset and CPUAnalyse signals.

An additional control signal (LPIn) re-starts the ST20450 from low power mode (see Section 11.2 on page 68 for further details on low power operation).

9.1.1 Reset

notRST initializes the device and causes it to enter its boot sequence which can either be in off-chip ROM or can be received down a link (see Section 9.2 on bootstrap). notRST must be asserted at power-on.

When notRST is asserted low, all modules are forced into their power-on reset condition. The clocks are stopped. The rising edge of notRST is internally synchronized and delayed until the clocks are stable before starting the initialization sequence.

CPUReset is provided as a functional reset which is quicker to reboot as the PLL is not reset. In other respects the effect is the same as notRST. CPUReset can be used in conjunction with CPUAnalyse.

The ResetRespOut signal provides additional information with regard to the progress of internal reset activities and generally as a CPU running signal. The ResetRespOut signal when low signals that the CPU has halted following a halt-on-error or a CPUAnalyse.

9.1.2 CPUAnalyse

If CPUAnalyse is taken high when the ST20450 is running, the ST20450 will halt at the next descheduling point. CPUReset may then be asserted. When CPUReset comes low again the ST20450 will be in its reset state, and information on the state of the machine when it was halted by the assertion of CPUAnalyse, is maintained permitting analysis of the halted machine.

An input link will continue with outstanding transfers. An output link will not make another access to memory for data but will transmit only those bytes already in the link buffer. Providing there is no delay in link acknowledgement, the link will be inactive within a few microseconds of the ST20450 halting.

If CPUAnalyse is taken low without CPUReset going high the processor state and operation are undefined.

9.1.3 Errors

Software errors, such as arithmetic overflow or array bounds violation, can cause an error flag to be set. This flag is directly connected to the ErrorOut pin. The ST20450 can be set to ignore the error flag in order to optimize the performance of a proven program. If error checks are removed any unexpected error then occurring will have an arbitrary undefined effect. The ST20450 can
alternatively be set to halt-on-error to prevent further corruption and allow postmortem debugging. The ST20450 also supports user defined trap handlers, see Section 4.6 on page 21 for details.

If a high priority process pre-empts a low priority one, status of the Error and HaltOnError flags is saved for the duration of the high priority process and restored at the conclusion of it. Status of both flags is transmitted to the high priority process. Either flag can be altered in the process without upsetting the error status of any complex operation being carried out by the pre-empted low priority process.

In the event of a processor halting because of HaltOnError, the links will finish outstanding transfers before shutting down. If CPUAnalyse is asserted then all inputs continue but outputs will not make another access to memory for data. Memory refresh will continue to take place.

9.2 Bootstrap

The ST20450 can be bootstrapped from external ROM, internal ROM or from a link. This is determined by the setting of the BootSrce0-1 pins, see Table 9.1 on page 51. If both BootSrce0-1 pins are held low it will boot from a link. If either or both pins are held high, it will boot from ROM. This is sampled once only by the ST20450, before the first instruction is executed after reset.

9.2.1 Booting from ROM

When booting from ROM, the ST20450 starts to execute code from the top two bytes in external memory, at address #7FFFFFFE which should contain a backward jump to a program in ROM.

9.2.2 Booting from link

When booting from a link, the ST20450 will wait for the first bootstrap message to arrive on the link. The first byte received down the link is the control byte. If the control byte is greater than 1 (i.e. 2 to 255), it is taken as the length in bytes of the boot code to be loaded down the link. The bytes following the control byte are then placed in internal memory starting at location MemStart. Following reception of the last byte the ST20450 will start executing code at MemStart. The memory space immediately above the loaded code is used as work space. A byte arriving on other links after the control byte has been received, and on the bootstrapping link after the last bootstrap byte, is retained and no acknowledge is sent until a process inputs from the link.

9.2.3 Peek and poke

Any location in internal or external memory can be interrogated and altered when the ST20450 is waiting for a bootstrap from link.

When booting from link, if the first byte (the control byte) received down the link is greater than 1, it is taken as the length in bytes of the boot code to be loaded down the link.

If the control byte is 0 then eight more bytes are expected on the link. The first four byte word is taken as an internal or external memory address at which to poke (write) the second four byte word.

If the control byte is 1 the next four bytes are used as the address from which to peek (read) a word of data; the word is sent down the output channel of the link.
Note, peeks and pokes in the address range #20000000 to #3FFFFFFF access the internal peripheral device registers. Therefore they can be used to configure the EMI before booting. Note that addresses that overlap the internal peripheral addresses (#20000000 to 3FFFFFFF) can not be accessed via the link.

Following a peek or poke, the ST20450 returns to its previously held state. Any number of accesses may be made in this way until the control byte is greater than 1, when the ST20450 will commence reading its bootstrap program. Any link can be used but addresses and data must be transmitted via the same link as the control byte.
10 Test Access Port

The ST20450A conforms to IEEE standard 1149.1, with the exception of the EventWaiting pin, as reported in the ST20450 bug list.

The Test Access Port (TAP) consists of five pins: TMS, TCK, TDI, TDO and notTRST. TDO can be overdriven to the power rails, and TCK can be stopped in either logic state.

The instruction register is 5 bits long, with no parity, and the pattern “00001” is loaded into the register during the Capture-IR state.

There are four defined public instructions, see Table 10.1. All other instruction codes are reserved.

<table>
<thead>
<tr>
<th>Instruction code a</th>
<th>Instruction</th>
<th>Selected register</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 0 0 0 0</td>
<td>EXTEST</td>
<td>Boundary-Scan</td>
</tr>
<tr>
<td>0 0 0 0 1</td>
<td>IDCODE</td>
<td>Identification</td>
</tr>
<tr>
<td>0 0 0 1 0</td>
<td>SAMPLE/PRELOAD</td>
<td>Boundary-Scan</td>
</tr>
<tr>
<td>1 1 1 1 1</td>
<td>BYPASS</td>
<td>Bypass</td>
</tr>
</tbody>
</table>

Table 10.1 Instruction codes

a. MSB ... LSB; LSB closest to TDO.

There are three test data registers; Bypass, Boundary-Scan and Identification. These registers operate according to 1149.1. The operation of the Boundary-Scan register is defined in the BSDL description, see Appendix A on page 99.

The identification code is 05000011, see Table 10.2.

<table>
<thead>
<tr>
<th>Bit 31</th>
<th>Bit 0 a</th>
<th>Mask Rev</th>
<th>ST20 family</th>
<th>Variant</th>
<th>SGS-THOMSON manufacturers id</th>
<th>c</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 0 0 0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 1</td>
<td>0 5 0 0 0 0 1 1</td>
<td>b ST20 family</td>
<td>Variant</td>
<td>SGS-THOMSON manufacturers id</td>
<td>c</td>
<td></td>
</tr>
</tbody>
</table>

Table 10.2 Identification code

a. Closest to TDO.
b. 0 indicates SGS-THOMSON part, 1 indicates customer part.
c. Defined as 1 in IEEE 1149.1 standard.
11 Clocks and low power operation

11.1 Clocks

Two on-chip phase locked loops (PLL) generate all the internal high frequency clocks. The PLLs are used to generate the internal clock frequencies needed for the CPU and the OS-Links. Alternatively a direct clock input can provide the system clocks.

Internal clocks may be turned off (including PLLs) enabling power down mode.

There are two clock inputs, one for the system clock (ClockIn) and one for the link clock (LinkClockIn). ClockIn must be in the range 3.2 to 10 MHz for PLL operation, see Table 11.1. LinkClockIn must be 5 MHz during PLL operation for compatibility with the Development System and other standard OS-Link products.

The ST20450 can be set to operate in TimesOneMode, which is when the PLL is bypassed. During TimesOneMode for either clock the relevant input clock must be in the range 0 to 32 MHz and should be nominally 50/50 mark space ratio.

11.1.1 Processor speed select

The speed of the internal processor clock is variable in discrete steps. The clock rate at which the ST20450 runs at is determined by the logic levels applied on the three speed select lines ProcSpeed0-2 as detailed in Table 11.1. The frequency of ClockIn for the processor speeds given in the table is nominally 5 MHz.

<table>
<thead>
<tr>
<th>ProcSpeed2</th>
<th>ProcSpeed1</th>
<th>ProcSpeed0</th>
<th>Processor clock speed MHz</th>
<th>Processor cycle time ns</th>
<th>Phase lock loop factor (PLLx)</th>
<th>Allowable ClockIn range MHz</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>TimesOneMode</td>
<td></td>
<td></td>
<td>0 - 32</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>RESERVED</td>
<td></td>
<td></td>
<td>RESERVED</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>RESERVED</td>
<td></td>
<td></td>
<td>RESERVED</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>30</td>
<td>33.3</td>
<td>6</td>
<td>5 - 8.3</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>40</td>
<td>25.0</td>
<td>8</td>
<td>4 - 6.25</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>RESERVED</td>
<td></td>
<td></td>
<td>RESERVED</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>RESERVED</td>
<td></td>
<td></td>
<td>RESERVED</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>RESERVED</td>
<td></td>
<td></td>
<td>RESERVED</td>
</tr>
</tbody>
</table>

Table 11.1 Processor speed selection

11.2 Low power control

The ST20450 is designed for 0.5 micron, 3.3V CMOS technology and runs at speeds of up to 40 MHz. 3.3V operation provides reduced power consumption internally and allows the use of low power peripherals. In addition, to enhance the potential for battery operation further, a low power power-down mode is available on the ST20450.

The different power levels of the ST20450 are listed below.

- Operating power - power consumed during functional operation.
• Standby power - power consumed during little or no activity. The CPU is idle but ready to immediately respond to an interrupt/reschedule.

• Power-down - internal clocks are stopped and power consumption is significantly reduced. Functional operation is stalled. Normal functional operation can be resumed from previous state as soon as the clocks are stable as all internal logic is static no information is lost during power-down.

The ST20450 enters power-down when:
  • LPIn is high - irrespective of all other device activity.

The ST20450 exits power-down when:
  • LPIn goes low.

In power-down mode the processor and all peripherals are stopped, including the external memory controller and optionally the PLLs. Effectively the internal clock is stopped and functional operation is stalled. On restart the clock is restarted and the chip resumes normal functional operation.

Low power operation can be achieved in one of two ways, as listed below.

• Availability of direct clock input - this allows external control of clocking directly and thus direct control of power consumption. (Available in TimesOneMode only).

• Global system clock may be stopped, using the LPIn pin as described above. In this case the external clock remains running. This mechanism allows any PLLs to be kept running (if desired) so that wake-up from low power mode will be fast.

Note, DRAM refresh is not supported in power-down mode and DMA Request requires special attention to work correctly.

### 11.2.1 Low power configuration registers

The low power controller is allocated a 4k block of memory in the internal peripheral address space. Information on low power mode is stored in registers as detailed in the following section. The registers can be examined and set by the devlw (device load word) and devsw (device store word) instructions. Note, they can not be accessed using memory instructions.

**LPSysPll**

The LPSysPll register controls what happens to the System Clock in PLL operation when low power mode is entered.

<table>
<thead>
<tr>
<th>LPSysPll</th>
<th>#20001420</th>
<th>Read/Write</th>
</tr>
</thead>
<tbody>
<tr>
<td>Bit</td>
<td>Bit field</td>
<td>Function</td>
</tr>
<tr>
<td>1:0</td>
<td>LPSysPll</td>
<td>determines the system clock PLL when low power mode is entered, as follows:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>LPSysPll1:0 System clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td>00 PLL off</td>
</tr>
<tr>
<td></td>
<td></td>
<td>01 PLL reference on</td>
</tr>
<tr>
<td></td>
<td></td>
<td>10 PLL reference on</td>
</tr>
<tr>
<td></td>
<td></td>
<td>11 PLL on</td>
</tr>
</tbody>
</table>

Table 11.2 Bit fields in the LPSysPll register
The **LPLinkPll** register controls what happens to the Link Clock PLL when low power mode is entered.

<table>
<thead>
<tr>
<th>LPLinkPll</th>
<th>#20001424</th>
<th>Read/Write</th>
</tr>
</thead>
<tbody>
<tr>
<td>Bit</td>
<td>Bit field</td>
<td>Function</td>
</tr>
<tr>
<td>2:0</td>
<td>LPLinkPll</td>
<td>Determines the link clock PLL when low power mode is entered, as follows:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>LPLinkPll2:0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>000</td>
</tr>
<tr>
<td></td>
<td></td>
<td>001</td>
</tr>
<tr>
<td></td>
<td></td>
<td>010</td>
</tr>
<tr>
<td></td>
<td></td>
<td>011</td>
</tr>
<tr>
<td></td>
<td></td>
<td>100</td>
</tr>
<tr>
<td></td>
<td></td>
<td>101</td>
</tr>
<tr>
<td></td>
<td></td>
<td>110</td>
</tr>
<tr>
<td></td>
<td></td>
<td>111</td>
</tr>
</tbody>
</table>

Table 11.3 Bit fields in the **LPLinkPll** register

**SysRatio**

The **SysRatio** register is a read only register and gives the speed that the system PLL is running at. It contains the relevant PLL multiply ratio when using a PLL, or contains the value ‘1’ when in **TimesOneMode** for that PLL.

**LinkRatio**

The **LinkRatio** register is a read only register and gives the speed that the link PLL is running at. It contains the relevant PLL multiply ratio when using a PLL, or contains the value ‘1’ when in **TimesOneMode** for that PLL.

Note that for the OS-Links the clock speed is 2.5 times the data rate, thus a multiply ratio of 10 with a 5 MHz input clock rate is equivalent to a link speed of 20 Mbits/s.

### 11.3 Wakeup times and power consumption during standby

In standby the system and link PLLs have a number of possible states, determined by the setting of the **LPSysPll** and **LPLinkPll** registers, which allow a compromise between wakeup time and power consumption during standby.

<table>
<thead>
<tr>
<th>System PLL state during standby</th>
<th>Approximate wakeup time</th>
<th>Power in standby</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>Running</td>
<td>3 LPC clocks + 6 system (CPU) clocks</td>
<td>20 mW</td>
<td>1</td>
</tr>
<tr>
<td>Standby</td>
<td>0.5 ms</td>
<td>2 mW + leakage 1</td>
<td></td>
</tr>
<tr>
<td>Off (default)</td>
<td>2 ms</td>
<td>Leakage 1</td>
<td></td>
</tr>
</tbody>
</table>

Notes

1. Leakage is 3.5 mW maximum at 125 °C die temperature.

Table 11.4 System PLL options
Notes

1. Leakage is 3.5 mW maximum at 125 °C die temperature.

Table 11.5 Link PLL options

<table>
<thead>
<tr>
<th>Link PLL state during standby</th>
<th>Approximate wakeup time</th>
<th>Power in standby</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>Running and clocking OS-Link engine</td>
<td>0</td>
<td>40 mW</td>
<td></td>
</tr>
<tr>
<td>Running</td>
<td>3 LPC clocks + 6 system (CPU) clocks</td>
<td>20 mW</td>
<td></td>
</tr>
<tr>
<td>Standby</td>
<td>0.5 ms</td>
<td>2 mW + leakage</td>
<td>1</td>
</tr>
<tr>
<td>Off (default)</td>
<td>2 ms</td>
<td>leakage</td>
<td>1</td>
</tr>
</tbody>
</table>

11.4 Clocking sources

The low power timer and alarm must be clocked at all times by the following clocking source:

- External clock input (LPClockIn) - this clock can be at any rate below 5 MHz provided it is not more than one eighth of the system clock rate.
12 Serial link interface (OS-Link)

The ST20450 has an OS-Link based serial communications subsystem. The OS-Link is used to provide serial data transfer and its main function is for booting the device during software development.

The OS-Link is a serial communications engine consisting of two signal wires, one in each direction. OS-Links use an asynchronous bit-serial (byte-stream) protocol, each bit received is sampled five times, hence the term oversampled links (OS-Links). The OS-Link provides a pair of channels, one input and one output channel.

The OS-Link is used for the following purposes:

- **Bootstrapping** - the program which is executed at power up or after reset can reside in ROM in the address space, or can be loaded via the OS-Link directly into memory.
- **Diagnostics** - diagnostic and debug software can be downloaded over the link connected to a PC or other diagnostic equipment, and the system performance and functionality can be monitored.
- **Connection to external peripherals** - interface devices are available that allow OS-Links to be interfaced to standard peripherals and buses. A macrocell is also available to give OS-Link to parallel interface conversion for use on external ASIC based peripherals.
- **Multiprocessing** - OS-Links allow the ST20450 to be directly connected in a multiprocessor system with other OS-Link devices. Inter-processor communication is directly supported in software.

12.1 OS-Link protocol

The quiescent state of a link output is low. Each data byte is transmitted as a high start bit followed by a one bit followed by eight data bits followed by a low stop bit (see Figure 12.1). The least significant bit of data is transmitted first. After transmitting a data byte the sender waits for the acknowledge, which consists of a high start bit followed by a zero bit. The acknowledge signifies both that a process was able to receive the acknowledged data byte and that the receiving link is able to receive another byte. The sending link reschedules the sending process only after the acknowledge for the final byte of the message has been received. The link allows an acknowledge to be sent before the data has been fully received.

![Figure 12.1 OS-Link data and acknowledge formats](image-url)
12.2 OS-Link speed

The bandwidth of each link is selectable to 10 or 20 Mbits/s, Link0 can also be set to run at 5 Mbits/s if the Link0Special pin is set high, see Table 12.1. Links are not synchronized with the input clock or the processor clock and are insensitive to their phases. Thus links from independently clocked systems may communicate, providing only that the clocks are nominally identical and within specification.

<table>
<thead>
<tr>
<th>LinkSpeed1</th>
<th>LinkSpeed0</th>
<th>Link0Special</th>
<th>Link1-3 speed</th>
<th>Link0 speed</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>X</td>
<td>TimesOneMode</td>
<td>TimesOneMode</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>10 Mbits/s</td>
<td>10 Mbits/s</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>20 Mbits/s</td>
<td>20 Mbits/s</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>X</td>
<td>RESERVED</td>
<td>RESERVED</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>10 Mbits/s</td>
<td>5 Mbits/s</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>20 Mbits/s</td>
<td>10 Mbits/s</td>
</tr>
</tbody>
</table>

Table 12.1 Link speed settings

The links can be run at TimesOneMode, i.e. with the PLL bypassed. When the links are in TimesOneMode they actually run at the speed of the link clock divided by 2.5. For example, with the link clock at 50 MHz, Link1-3 run at 20 Mbits/s and Link0 runs at 10 or 20 Mbits/s depending on the setting of the Link0Special pin, see Table 12.2.

<table>
<thead>
<tr>
<th>LinkSpeed1:0</th>
<th>Link0Special</th>
<th>Link1-3 speed</th>
<th>Link0 speed</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>0</td>
<td>20 Mbits/s</td>
<td>20 Mbits/s</td>
</tr>
<tr>
<td>00</td>
<td>1</td>
<td>20 Mbits/s</td>
<td>10 Mbits/s</td>
</tr>
</tbody>
</table>

Table 12.2 Link speeds when set to TimesOneMode with the link clock at 50 MHz
12.3 OS-Link connections

Links are TTL compatible and intended to be used in electrically quiet environments, between devices on a single printed circuit board or between two boards via a backplane. Direct connection may be made between devices separated by a distance of less than 300 mm. For longer distances a matched 100 ohm transmission line should be used with series matching resistors (RM), see Figure 12.3. When this is done the line delay should be less than 0.4 bit time to ensure that the reflection returns before the next data bit is sent. Buffers may be used for very long transmissions, see Figure 12.4. If so, their overall propagation delay should be stable within the skew tolerance of the link, although the absolute value of the delay is immaterial.

Figure 12.2 OS-Links directly connected

Figure 12.3 OS-Links connected by transmission line

Figure 12.4 OS-Links connected by buffers
12.4 Event

EventReq and EventAck provide an asynchronous handshake interface between an external event and an internal process. Event channels provide process synchronization but cannot transfer any data. When an external event takes EventReq high the external event channel (additional to the external link channels) is made ready to communicate with a process. When both the event channel and the process are ready the processor takes EventAck high and the process, if waiting, is scheduled. EventAck is removed after EventReq goes low.

EventWaiting is asserted high when a process executes an input on the event channel. Note, the EventWaiting pin can only be asserted by executing an in instruction, it is not asserted high when an enable channel (enbc) instruction is executed on the event channel. EventWaiting remains high whilst the device is waiting for or servicing EventReq and is returned low when EventAck goes high. The EventWaiting pin changes near the falling edge of ProcClockOut and can therefore be sampled by the rising edge of ProcClockOut.

EventWaiting allows a process to control external logic; for example, to clock a number of inputs into a memory mapped data latch so that the event request type can be determined.

Only one process may use the event channel at any given time. If no process requires an event to occur EventAck will never be taken high. Although EventReq triggers the channel on a transition from low to high, it must not be removed before EventAck is high. EventReq should be low during Reset; if not it will be ignored until it has gone low and returned high. EventAck is taken low when Reset occurs.

If the process is a high priority one and no other high priority process is running, typical latency is 19 processor cycles, and maximum latency (assuming all memory accesses are internal) is 58 processor cycles.

Setting a high priority task to wait for an event input allows the user to interrupt a program running at low priority. The time taken from asserting EventReq to the execution of the microcode interrupt handler in the CPU is four cycles. The following functions take place during the four cycles:

- **Cycle 1** Sample EventReq at pad on the rising edge of ProcClockOut and synchronize.
- **Cycle 2** Edge detect the synchronized EventReq and form the interrupt request.
- **Cycle 3** Sample interrupt vector for microcode ROM in the CPU.
- **Cycle 4** Execute the interrupt routine for the event rather than the next instruction.
13 Software development

Software development support for the ST20450 is provided by the ST20 Toolset which includes a range of advanced debugging tools supporting a windows based graphical user interface (GUI) for PC and UNIX machines.

13.1 ST20 toolset

The ST20 toolset provides a range of tools to support the developer including:

- Compiler - full ANSI validated optimizing C compiler, with support for assembly language programming.
- Runtime libraries - full ANSI validated libraries.
- Compacting linker and Librarian - support for user, application and run-time libraries.
- Configurer - support to the mapping of an application onto an ST20 processor.
- Mapping tool - conversion of symbolic to absolute addresses.
- ROM tool - support EPROM programming.
- Memory configuration tool - support for initializing the EMI.

Refer to the *ST20 ANSI C Toolset Datasheet* (document number 42 1669 00) for further details.

13.1.1 Debugging and profiling software

Debugging and profiling software includes an extended range of tools supporting a window based GUI appropriate to the development host:

- Windows 3.1 for PC machines
- OSF Motif for UNIX machines
- Profiler - conventional profiling tool.
- Load monitor - profile of the CPU usage, hot/cold spots, computation loading, communications loading.
- INQUEST windowing debugger - providing source and assembler debugging with watchpoints, breakpoints, single stepping, stack trace and symbolic data inspection.

Further details can be found in the *PC ST20 Inquest Datasheet* (document number 42 1668 00) and the *Sun 4 ST20 Inquest Datasheet* (document number 42 1667 00).
14 Configuration register addresses

This chapter lists all the ST20450 configuration registers and gives the addresses of the registers. The complete bit format of each of the registers and its functionality is given in the relevant chapter. The registers can be examined and set by the *devlw* (device load word) and *devsw* (device store word) instructions. Note, they can not be accessed using memory instructions.

<table>
<thead>
<tr>
<th>Register</th>
<th>Address</th>
<th>Size</th>
<th>Set</th>
<th>Clear</th>
<th>Read/Write</th>
<th>Ref page</th>
</tr>
</thead>
<tbody>
<tr>
<td>HandlerWptr0</td>
<td>#20000000</td>
<td>30</td>
<td>R/W</td>
<td>R/W</td>
<td></td>
<td>24</td>
</tr>
<tr>
<td>HandlerWptr1</td>
<td>#20000004</td>
<td>30</td>
<td>R/W</td>
<td>R/W</td>
<td></td>
<td></td>
</tr>
<tr>
<td>HandlerWptr2</td>
<td>#20000008</td>
<td>30</td>
<td>R/W</td>
<td>R/W</td>
<td></td>
<td></td>
</tr>
<tr>
<td>HandlerWptr3</td>
<td>#2000000C</td>
<td>30</td>
<td>R/W</td>
<td>R/W</td>
<td></td>
<td></td>
</tr>
<tr>
<td>HandlerWptr4</td>
<td>#20000010</td>
<td>30</td>
<td>R/W</td>
<td>R/W</td>
<td></td>
<td></td>
</tr>
<tr>
<td>HandlerWptr5</td>
<td>#20000014</td>
<td>30</td>
<td>R/W</td>
<td>R/W</td>
<td></td>
<td></td>
</tr>
<tr>
<td>HandlerWptr6</td>
<td>#20000018</td>
<td>30</td>
<td>R/W</td>
<td>R/W</td>
<td></td>
<td></td>
</tr>
<tr>
<td>HandlerWptr7</td>
<td>#2000001C</td>
<td>30</td>
<td>R/W</td>
<td>R/W</td>
<td></td>
<td></td>
</tr>
<tr>
<td>TriggerMode0</td>
<td>#20000040</td>
<td>3</td>
<td>R/W</td>
<td>R/W</td>
<td></td>
<td>24</td>
</tr>
<tr>
<td>TriggerMode1</td>
<td>#20000044</td>
<td>3</td>
<td>R/W</td>
<td>R/W</td>
<td></td>
<td></td>
</tr>
<tr>
<td>TriggerMode2</td>
<td>#20000048</td>
<td>3</td>
<td>R/W</td>
<td>R/W</td>
<td></td>
<td></td>
</tr>
<tr>
<td>TriggerMode3</td>
<td>#2000004C</td>
<td>3</td>
<td>R/W</td>
<td>R/W</td>
<td></td>
<td></td>
</tr>
<tr>
<td>TriggerMode4</td>
<td>#20000050</td>
<td>3</td>
<td>R/W</td>
<td>R/W</td>
<td></td>
<td></td>
</tr>
<tr>
<td>TriggerMode5</td>
<td>#20000054</td>
<td>3</td>
<td>R/W</td>
<td>R/W</td>
<td></td>
<td></td>
</tr>
<tr>
<td>TriggerMode6</td>
<td>#20000058</td>
<td>3</td>
<td>R/W</td>
<td>R/W</td>
<td></td>
<td></td>
</tr>
<tr>
<td>TriggerMode7</td>
<td>#2000005C</td>
<td>3</td>
<td>R/W</td>
<td>R/W</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Pending</td>
<td>#20000080</td>
<td>8</td>
<td>Interrupt trigger</td>
<td>Interrupt grant</td>
<td>R/W</td>
<td>26</td>
</tr>
<tr>
<td>Set-Pending</td>
<td>#20000084</td>
<td>8</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Clear-Pending</td>
<td>#20000088</td>
<td>8</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Mask</td>
<td>#200000C0</td>
<td>9</td>
<td>R/W</td>
<td></td>
<td></td>
<td>25</td>
</tr>
<tr>
<td>Set-Mask</td>
<td>#200000C4</td>
<td>9</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Clear-Mask</td>
<td>#200000C8</td>
<td>9</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Exec</td>
<td>#2000100</td>
<td>8</td>
<td>Interrupt valid</td>
<td>Interrupt done</td>
<td>R/W</td>
<td>27</td>
</tr>
<tr>
<td>Set-Exec</td>
<td>#2000104</td>
<td>8</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Clear-Exec</td>
<td>#2000108</td>
<td>8</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>LPSysPll</td>
<td>#2001420</td>
<td>2</td>
<td>R/W</td>
<td></td>
<td></td>
<td>69</td>
</tr>
<tr>
<td>LPLinkPll</td>
<td>#2001424</td>
<td>3</td>
<td>R/W</td>
<td></td>
<td></td>
<td>70</td>
</tr>
<tr>
<td>SysRatio</td>
<td>#2001500</td>
<td>6</td>
<td>R</td>
<td></td>
<td></td>
<td>70</td>
</tr>
</tbody>
</table>

Table 14.1 ST20450 register addresses
<table>
<thead>
<tr>
<th>Register</th>
<th>Address</th>
<th>Size</th>
<th>Set</th>
<th>Clear</th>
<th>Read/Write</th>
<th>Ref page</th>
</tr>
</thead>
<tbody>
<tr>
<td>LinkRatio</td>
<td>#20001504</td>
<td>6</td>
<td></td>
<td></td>
<td>R</td>
<td>70</td>
</tr>
<tr>
<td>ConfigDataField0</td>
<td>#20002000</td>
<td>32</td>
<td></td>
<td>R/W</td>
<td>R/W</td>
<td>52</td>
</tr>
<tr>
<td>ConfigDataField1</td>
<td>#20002004</td>
<td>32</td>
<td></td>
<td>R/W</td>
<td>R/W</td>
<td></td>
</tr>
<tr>
<td>ConfigDataField2</td>
<td>#20002008</td>
<td>32</td>
<td></td>
<td>R/W</td>
<td>R/W</td>
<td></td>
</tr>
<tr>
<td>ConfigDataField3</td>
<td>#2000200C</td>
<td>32</td>
<td></td>
<td>R/W</td>
<td>R/W</td>
<td></td>
</tr>
<tr>
<td>ConfigCommand</td>
<td>#20002010</td>
<td>32</td>
<td></td>
<td>W</td>
<td>W</td>
<td>51</td>
</tr>
<tr>
<td>ConfigStatus</td>
<td>#20002020</td>
<td>32</td>
<td></td>
<td>R</td>
<td>R</td>
<td>52</td>
</tr>
</tbody>
</table>

Table 14.1 ST20450 register addresses
15 Electrical specifications

15.1 Absolute maximum ratings

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>VDD</td>
<td>DC supply voltage</td>
<td>3.6</td>
<td>V</td>
<td></td>
<td></td>
</tr>
<tr>
<td>V{i}</td>
<td>Voltage on input pins</td>
<td>GND-0.6</td>
<td>5.75</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>V{o}</td>
<td>Voltage on bi-directional and output pins</td>
<td>GND-0.6</td>
<td>VDD+0.6</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>{i}o</td>
<td>DC output current</td>
<td>25</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>T{s}</td>
<td>Storage temperature (ambient)</td>
<td>-55</td>
<td>125</td>
<td>°C</td>
<td></td>
</tr>
<tr>
<td>T{a}</td>
<td>Temperature under bias (ambient)</td>
<td>-55</td>
<td>125</td>
<td>°C</td>
<td></td>
</tr>
<tr>
<td>P{d}max</td>
<td>Power dissipation</td>
<td>1.98</td>
<td>W</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Notes
1 Stresses greater than those listed under ‘Absolute maximum ratings’ may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operating sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

Table 15.1 Absolute maximum ratings

15.2 Operating conditions

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>{i}i, {o}o</td>
<td>Input or output voltage</td>
<td>0</td>
<td>VDD</td>
<td>V</td>
<td>1</td>
</tr>
<tr>
<td>C{l}</td>
<td>Load capacitance per pin</td>
<td>60</td>
<td>pF</td>
<td></td>
<td>2</td>
</tr>
<tr>
<td>C{ld}</td>
<td>Load capacitance per data pin</td>
<td>60</td>
<td>pF</td>
<td></td>
<td></td>
</tr>
<tr>
<td>C{la}</td>
<td>Load capacitance per address/strobe pin</td>
<td>100</td>
<td>pF</td>
<td></td>
<td></td>
</tr>
<tr>
<td>T{a}</td>
<td>Operating temperature (ambient)</td>
<td>0</td>
<td>70</td>
<td>°C</td>
<td></td>
</tr>
<tr>
<td></td>
<td>ST20450-S</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Notes
1 Excursions beyond the supplies are permitted but not recommended; see DC characteristics.
2 Excluding LinkOut load capacitance and EMI pin load capacitance.

Table 15.2 Operating conditions
15.3 DC specifications

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Min</th>
<th>Typical</th>
<th>Max</th>
<th>Units</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>VDD</td>
<td>Positive supply voltage</td>
<td>3.0</td>
<td>3.3</td>
<td>3.6</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>VᵢH</td>
<td>Input logic 1 voltage (bi-directional pins and LPClockIn pin)</td>
<td>2.0</td>
<td>VDD+0.5</td>
<td></td>
<td>V</td>
<td></td>
</tr>
<tr>
<td></td>
<td>Input logic 1 voltage (input pins)</td>
<td>2.0</td>
<td>5.75</td>
<td></td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>VᵢL</td>
<td>Input logic 0 voltage</td>
<td>-0.5</td>
<td>0.8</td>
<td></td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>IᵢN</td>
<td>Input current (input pin)</td>
<td>±10</td>
<td>µA</td>
<td>1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>IₒZ</td>
<td>Off state digital output current</td>
<td>±50</td>
<td>µA</td>
<td>1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>VₒHDC</td>
<td>Output logic 1 voltage</td>
<td>2.4</td>
<td>V</td>
<td>2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>VₒLDC</td>
<td>Output logic 0 voltage</td>
<td>0.4</td>
<td>V</td>
<td>2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>CᵢN</td>
<td>Input capacitance (input pins)</td>
<td>7</td>
<td>pF</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Input capacitance (bi-directional pins)</td>
<td>14</td>
<td>pF</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CₒUT</td>
<td>Output capacitance</td>
<td>15</td>
<td>pF</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Notes

1  \(0 \leq Vᵢ \leq VDD\)
2  \(I_{load}=2mA\)

Table 15.3 DC specifications
16 Timing specifications

16.1 EMI timings

The timings are based on the following loading conditions: 50 pF load with the pad drive strengths (see Table 8.15 on page 61 for details on the pad drive strength) as follows:

- **MemAddr2-31** drive strength at level 1
- **Strobe** drive strength at level 1
- **MemData0-31** drive strength at level 3

<table>
<thead>
<tr>
<th>Symbol</th>
<th>No.</th>
<th>Parameter</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>tCHAV</td>
<td>1</td>
<td>Reference Clock high to Address valid</td>
<td>-6.8</td>
<td>0.0</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tCLSV</td>
<td>2</td>
<td>Reference Clock low to Strobe valid</td>
<td>-6.0</td>
<td>2.3</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tCHSV</td>
<td>3</td>
<td>Reference Clock high to Strobe valid</td>
<td>-5.7</td>
<td>0.0</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tRDVCH</td>
<td>4</td>
<td>Read Data valid to Reference Clock high</td>
<td></td>
<td></td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tCHRDX</td>
<td>5</td>
<td>Read Data hold after Reference Clock high</td>
<td></td>
<td></td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tCLWDV</td>
<td>6</td>
<td>Reference Clock low to Write Data valid</td>
<td>-7.3</td>
<td>2.9</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tCHWDV</td>
<td>7</td>
<td>Reference Clock high to Write Data valid</td>
<td>-6.3</td>
<td>1.9</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tCHRSV</td>
<td>8</td>
<td>Reference Clock high to remaining Strobes valid</td>
<td>-4.9</td>
<td>5.6</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tCHPH</td>
<td>9</td>
<td>Reference Clock high to ProcClkOut</td>
<td>-6.1</td>
<td>0.7</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tWVCH</td>
<td>10</td>
<td>MemWait valid to Reference Clock high</td>
<td></td>
<td></td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tCHWX</td>
<td>11</td>
<td>MemWait hold after Reference Clock high</td>
<td></td>
<td></td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tRVCH</td>
<td>12</td>
<td>MemReq valid to Reference Clock high</td>
<td></td>
<td></td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tCHRX</td>
<td>13</td>
<td>MemReq hold after Reference Clock high</td>
<td></td>
<td></td>
<td>ns</td>
<td></td>
</tr>
</tbody>
</table>

Table 16.1 EMI cycle timings

Note, the ‘Reference Clock’ used in the EMI timings is a virtual clock and is defined as the point at which all positively edged EMI strobe and address outputs are valid. This is designed to remove process dependant skews from the datasheet description and highlight the dominant influence of address and strobe timings on memory system design.

All timing measurements are taken using a threshold of 1.5 V.
Figure 16.1 EMI timings
Figure 16.2 Rise and fall times for **MemData0-31** pins for different pad drive strengths

Figure 16.3 Rise and fall times for **MemAddr2-31** and strobe pins for different pad drive strengths
Figure 16.4 Rise and fall times for \textbf{ProcClkOut} at pad drive strength level 3

All rise and fall times are measured at 10 - 90 \%, on typical silicon at 3.3 V, 25^\circ\text{C}.
16.2 Link timings

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Min</th>
<th>Nom</th>
<th>Max</th>
<th>Units</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>tJQr</td>
<td>LinkOut rise time</td>
<td>20</td>
<td>10</td>
<td>0</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tJQf</td>
<td>LinkOut fall time</td>
<td>10</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>tJDh</td>
<td>LinkIn rise time</td>
<td>20</td>
<td>20</td>
<td></td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tJDi</td>
<td>LinkIn fall time</td>
<td></td>
<td>20</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>tJQJD</td>
<td>Buffered edge delay</td>
<td>0</td>
<td></td>
<td></td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>(\Delta tJB)</td>
<td>Variation in (t_JQJD)</td>
<td>20</td>
<td>3</td>
<td>1</td>
<td>ns</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>10 Mbits/s</td>
<td></td>
<td>10</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>5 Mbits/s</td>
<td></td>
<td>30</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLIZ</td>
<td>LinkIn capacitance</td>
<td>10</td>
<td>10</td>
<td></td>
<td>pF</td>
<td>1</td>
</tr>
<tr>
<td>CLL</td>
<td>LinkOut load capacitance</td>
<td>50</td>
<td></td>
<td></td>
<td>pF</td>
<td></td>
</tr>
</tbody>
</table>

Notes

1. This is the variation in the total delay through buffers, transmission lines, differential receivers etc, caused by such things as short term variation in supply voltages and differences in delays for rising and falling edges.

Table 16.2 Link timings

Figure 16.5 Link timings
16.3 Reset and Analyse timings

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Min</th>
<th>Nom</th>
<th>Max</th>
<th>Units</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>tRHRL</td>
<td>notRST pulse width low</td>
<td>8</td>
<td></td>
<td></td>
<td>ClockIn</td>
<td></td>
</tr>
<tr>
<td>tRHRL</td>
<td>CPUReset pulse width high</td>
<td>1</td>
<td></td>
<td></td>
<td>ClockIn</td>
<td></td>
</tr>
<tr>
<td>pAHRH</td>
<td>CPUAnalyse setup before CPUReset</td>
<td>3</td>
<td></td>
<td>ms</td>
<td></td>
<td>1</td>
</tr>
<tr>
<td>tRLAL</td>
<td>CPUAnalyse hold after CPUReset end</td>
<td>1</td>
<td></td>
<td></td>
<td>ClockIn</td>
<td></td>
</tr>
</tbody>
</table>

Notes

1. When ResetRespOut is high.

Table 16.3 Reset and Analyse timings

Figure 16.6 Buffered Link timings

Figure 16.7 Reset and Analyse timings
16.4 Event timings

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>tVHKH</td>
<td>EventReq response</td>
<td>0</td>
<td></td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tkHVL</td>
<td>EventReq hold</td>
<td>0</td>
<td></td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tVLKL</td>
<td>Delay before removal of</td>
<td>0</td>
<td></td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tKLVL</td>
<td>EventReq</td>
<td>0</td>
<td></td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tKLVL</td>
<td>Delay before re-assertion of EventReq</td>
<td>0</td>
<td></td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tkHEWL</td>
<td>EventAck to end of EventWaiting</td>
<td>0</td>
<td></td>
<td>ns</td>
<td></td>
</tr>
</tbody>
</table>

Table 16.4 Event timings

Figure 16.8 Event timings
16.5 Clock timings

16.5.1 ClockIn and LinkClockIn timings

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter Description</th>
<th>Min</th>
<th>Nom</th>
<th>Max</th>
<th>Units</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>tDCLDCH</td>
<td>ClockIn and LinkClockIn pulse width low for PLL operation</td>
<td>40</td>
<td></td>
<td></td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tDCHDCL</td>
<td>ClockIn and LinkClockIn pulse width high for PLL operation</td>
<td>40</td>
<td></td>
<td></td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tDCLDCL</td>
<td>ClockIn and LinkClockIn period for PLL operation</td>
<td>200</td>
<td></td>
<td></td>
<td>ns</td>
<td>1, 2</td>
</tr>
<tr>
<td>tDCr</td>
<td>ClockIn and LinkClockIn rise time for PLL operation</td>
<td>10</td>
<td></td>
<td></td>
<td>ns</td>
<td>3</td>
</tr>
<tr>
<td>tDCr</td>
<td>ClockIn and LinkClockIn fall time for PLL operation</td>
<td>8</td>
<td></td>
<td></td>
<td>ns</td>
<td>3</td>
</tr>
</tbody>
</table>

Notes

1 Measured between corresponding points on consecutive falling edges.
2 Variation of individual falling edges from their nominal times.
3 Clock transitions must be monotonic within the range VH to VL (see Electrical Specifications chapter).

Table 16.5 ClockIn and LinkClockIn timings

![Figure 16.9 ClockIn and LinkClockIn timings](image)
16.5.2 ProcClkOut timings

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>tPCLPCL</td>
<td>ProcClkOut period</td>
<td>22.5</td>
<td>27.5</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tPCHPCL</td>
<td>ProcClkOut pulse width high</td>
<td>10</td>
<td>15</td>
<td>ns</td>
<td>1</td>
</tr>
<tr>
<td>tPCLPCH</td>
<td>ProcClkOut pulse width low</td>
<td>10</td>
<td>15</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tPCstab</td>
<td>ProcClkOut stability</td>
<td>8</td>
<td>%</td>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>

Notes

1 Stability is the variation of cycle periods between two consecutive cycles, measured at corresponding points on the cycles.

Table 16.6 ProcClkOut timings

Figure 16.10 ProcClkOut timings
16.6 TAP timings

The TAP will function at 5 MHz TCK, with $T_{\text{setup}} = 10\,\text{ns}$ and $T_{\text{hold}} = 10\,\text{ns}$ for all inputs, and $T_{\text{prop}} = 50\,\text{ns}$ for all outputs. All other electrical characteristics of the TAP pins are as defined in Chapter 15 on page 79.

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Min</th>
<th>Nom</th>
<th>Max</th>
<th>Units</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>Tsetup</td>
<td>Set-up time</td>
<td>10</td>
<td></td>
<td></td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>Thold</td>
<td>Hold time</td>
<td>10</td>
<td></td>
<td></td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>Tprop</td>
<td>Propagation delay</td>
<td>50</td>
<td></td>
<td></td>
<td>ns</td>
<td></td>
</tr>
</tbody>
</table>

Table 16.7 TAP timings
17 Pin designations

Signal names are prefixed by not if they are active low, otherwise they are active high.

Supplies

<table>
<thead>
<tr>
<th>Pin</th>
<th>In/Out</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>VDD</td>
<td></td>
<td>Power supply</td>
</tr>
<tr>
<td>GND</td>
<td></td>
<td>Ground</td>
</tr>
</tbody>
</table>

Table 17.1 ST20450 supply pins

Clocks

<table>
<thead>
<tr>
<th>Pin</th>
<th>In/Out</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>ClockIn</td>
<td>in</td>
<td>System input clock - PLL or TimesOneMode</td>
</tr>
<tr>
<td>LinkClockIn</td>
<td>in</td>
<td>Link input clock - PLL or TimesOneMode</td>
</tr>
<tr>
<td>LPClockIn</td>
<td>in</td>
<td>Low power input clock</td>
</tr>
<tr>
<td>LPOsc</td>
<td>in/out</td>
<td>Low power clock oscillator</td>
</tr>
<tr>
<td>LPIn</td>
<td>in</td>
<td>Low power control</td>
</tr>
<tr>
<td>LPOut</td>
<td>out</td>
<td>Low power status</td>
</tr>
<tr>
<td>ProcClkOut</td>
<td>out</td>
<td>Processor clock</td>
</tr>
</tbody>
</table>

Table 17.2 ST20450 clocks and low power pins

System services

<table>
<thead>
<tr>
<th>Pin</th>
<th>In/Out</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>ProcSpeed0-2</td>
<td>in</td>
<td>Processor speed selectors</td>
</tr>
<tr>
<td>ResetRespOut</td>
<td>out</td>
<td>Reset response output</td>
</tr>
<tr>
<td>notRST</td>
<td>in</td>
<td>Reset</td>
</tr>
<tr>
<td>CPUReset</td>
<td>in</td>
<td>System reset</td>
</tr>
<tr>
<td>CPUAnalyse</td>
<td>in</td>
<td>Error analysis</td>
</tr>
</tbody>
</table>

Table 17.3 ST20450 system services pins

CPU

<table>
<thead>
<tr>
<th>Pin</th>
<th>In/Out</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>ErrorOut</td>
<td>out</td>
<td>Error indicator</td>
</tr>
<tr>
<td>ErrorIn</td>
<td>in</td>
<td>Error daisy-chain input</td>
</tr>
<tr>
<td>Debug0-7</td>
<td>out</td>
<td>Debug output</td>
</tr>
<tr>
<td>DebugIn</td>
<td>in</td>
<td>Debug input</td>
</tr>
</tbody>
</table>

Table 17.4 ST20450 CPU pins
**Interrupts**

<table>
<thead>
<tr>
<th>Pin</th>
<th>In/Out</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>Interrupt0-7</td>
<td>in</td>
<td>Interrupt</td>
</tr>
</tbody>
</table>

Table 17.5 ST20450 interrupt pins

**Memory**

<table>
<thead>
<tr>
<th>Pin</th>
<th>In/Out</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>MemAddr2-31</td>
<td>out</td>
<td>Address bus</td>
</tr>
<tr>
<td>MemData0-31</td>
<td>in/out</td>
<td>Data bus. <strong>Data0</strong> is the least significant bit (LSB) and <strong>Data31</strong> is the most significant bit (MSB).</td>
</tr>
<tr>
<td>notMemRd</td>
<td>out</td>
<td>Read strobe</td>
</tr>
<tr>
<td>MemReq</td>
<td>in</td>
<td>Direct memory access request</td>
</tr>
<tr>
<td>MemGranted</td>
<td>out</td>
<td>Direct memory access granted</td>
</tr>
<tr>
<td>MemRefPend</td>
<td>out</td>
<td>Dynamic memory refresh cycle is pending</td>
</tr>
<tr>
<td>notMemRf</td>
<td>out</td>
<td>Dynamic memory refresh indicator</td>
</tr>
<tr>
<td>MemWait</td>
<td>in</td>
<td>Memory cycle extender</td>
</tr>
<tr>
<td>notMemCAS0-3</td>
<td>out</td>
<td>CAS strobes - one per bank</td>
</tr>
<tr>
<td>notMemRAS0-3</td>
<td>out</td>
<td>RAS strobes - one per bank</td>
</tr>
<tr>
<td>notMemPS0-3</td>
<td>out</td>
<td>Programmable strobes - one per bank</td>
</tr>
<tr>
<td>notMemBE0-3</td>
<td>out</td>
<td>Byte enable strobes - one per bank</td>
</tr>
<tr>
<td>BootSrce0-1</td>
<td>in</td>
<td>Boot from ROM or from link</td>
</tr>
<tr>
<td>DisableRAM</td>
<td>in</td>
<td>Disables internal SRAM</td>
</tr>
</tbody>
</table>

Table 17.6 ST20450 memory pins

**Links**

<table>
<thead>
<tr>
<th>Pin</th>
<th>In/Out</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>LinkIn0-3</td>
<td>in</td>
<td>Four serial data input channels</td>
</tr>
<tr>
<td>LinkOut0-3</td>
<td>out</td>
<td>Four serial data output channels</td>
</tr>
<tr>
<td>Link0Special</td>
<td>in</td>
<td>Select special speed for Link 0</td>
</tr>
<tr>
<td>LinkSpeed0-1</td>
<td>in</td>
<td>Link speed selectors</td>
</tr>
</tbody>
</table>

Table 17.7 ST20450 link pins

**Event**

<table>
<thead>
<tr>
<th>Pin</th>
<th>In/Out</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>EventReq</td>
<td>in</td>
<td>Event request</td>
</tr>
<tr>
<td>EventAck</td>
<td>out</td>
<td>Event request acknowledge</td>
</tr>
<tr>
<td>EventWaiting</td>
<td>out</td>
<td>Event input requested by software</td>
</tr>
</tbody>
</table>

Table 17.8 ST20450 event pins
Test Access Port (TAP)

<table>
<thead>
<tr>
<th>Pin</th>
<th>In/Out</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>TDI</td>
<td>in</td>
<td>Test data input</td>
</tr>
<tr>
<td>TDO</td>
<td>out</td>
<td>Test data output</td>
</tr>
<tr>
<td>TMS</td>
<td>in</td>
<td>Test mode select</td>
</tr>
<tr>
<td>TCK</td>
<td>in</td>
<td>Test clock</td>
</tr>
<tr>
<td>notTRST</td>
<td>in</td>
<td>Test logic reset</td>
</tr>
</tbody>
</table>

Table 17.9  ST20450 TAP pins

Miscellaneous

<table>
<thead>
<tr>
<th>Pin</th>
<th>In/Out</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>MirrorADDEMI</td>
<td></td>
<td>No Connect (this refers to unused pins). Do not wire this pin.</td>
</tr>
<tr>
<td>Spare</td>
<td></td>
<td>No Connect (this refers to unused pins). Do not wire this pin.</td>
</tr>
</tbody>
</table>

Table 17.10  ST20450 miscellaneous pins
18 Package specifications

The ST20450 is available in a 208 pin plastic quad flat pack (PQFP) package.

18.1 ST20450 package pinout

Figure 18.1 ST20450 208 pin PQFP package pinout
## 18.2 ST20450 208 pin PQFP package dimensions

<table>
<thead>
<tr>
<th>REF.</th>
<th>CONTROL DIM. mm</th>
<th>ALTERNATIVE DIM. INCHES</th>
<th>NOTES</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>MIN</td>
<td>NOM</td>
<td>MAX</td>
</tr>
<tr>
<td>A</td>
<td></td>
<td></td>
<td>4.080</td>
</tr>
<tr>
<td>A1</td>
<td>0.25</td>
<td>-</td>
<td>0.40</td>
</tr>
<tr>
<td>A2</td>
<td>3.240</td>
<td>3.600</td>
<td>3.740</td>
</tr>
<tr>
<td>B</td>
<td>0.190</td>
<td>-</td>
<td>0.380</td>
</tr>
<tr>
<td>C</td>
<td>0.120</td>
<td>-</td>
<td>0.180</td>
</tr>
<tr>
<td>D</td>
<td>30.350</td>
<td>-</td>
<td>30.850</td>
</tr>
<tr>
<td>D1</td>
<td>27.900</td>
<td>28.000</td>
<td>28.100</td>
</tr>
<tr>
<td>D3</td>
<td>-</td>
<td>25.500</td>
<td>-</td>
</tr>
<tr>
<td>E</td>
<td>30.350</td>
<td>-</td>
<td>30.850</td>
</tr>
<tr>
<td>E1</td>
<td>27.900</td>
<td>28.000</td>
<td>28.100</td>
</tr>
<tr>
<td>E3</td>
<td>-</td>
<td>25.500</td>
<td>-</td>
</tr>
<tr>
<td>e</td>
<td>-</td>
<td>0.500</td>
<td>-</td>
</tr>
<tr>
<td>K</td>
<td>0</td>
<td>-</td>
<td>7</td>
</tr>
<tr>
<td>L</td>
<td>0.350</td>
<td>0.500</td>
<td>0.650</td>
</tr>
<tr>
<td>L1</td>
<td>-</td>
<td>1.300</td>
<td>-</td>
</tr>
<tr>
<td>Zd</td>
<td>-</td>
<td>1.250</td>
<td>-</td>
</tr>
<tr>
<td>Ze</td>
<td>-</td>
<td>1.250</td>
<td>-</td>
</tr>
</tbody>
</table>

### Notes

1. Lead finish to be 85 Sn/15 Pb solder plate.

Table 18.1 208 pin PQFP package dimensions
Figure 18.2 ST20450 208 pin PQFP package dimensions
18.3 ST20450 208 pin PQFP package thermal data

Maximum, still air thermal resistance is 55°C/W for the die in a 208 PQFP, with copper leadframe. Junction to case thermal resistance, measured to the centre of the upper side of the case, is 25°C/W.

Given a maximum operating junction temperature of 100°C the following maximum power conditions apply:

- Still air at 35°C: 2.5 W
- Still air at 85°C: 0.83 W
- Case held at 85°C: 1.85 W

Under certain operating conditions, the ST20450 device can dissipate up to 1.85 W. External thermal management is recommended, to ensure optimum performance and reliability.
19 Ordering information

<table>
<thead>
<tr>
<th>Device</th>
<th>Package</th>
</tr>
</thead>
<tbody>
<tr>
<td>ST20450X40S</td>
<td>208 pin plastic quad flatpack (PQFP)</td>
</tr>
</tbody>
</table>

For further information contact your local SGS-Thomson sales office.
Appendix A  Boundary scan description language (BSDL) file

--Version 0.2
--P J Dickinson, 30-08-95

entity ST20450A is

    generic (PHYSICAL_PIN_MAP : string := "PQFP208");

    port (VDD: linkage bit_vector (0 to 29);
          GND: linkage bit_vector (0 to 31);
          spare: linkage bit_vector (0 to 3);
          ClockIn, LinkClockIn, LPClockIn: in bit;
          LPClockOsc: linkage bit;
          -- this inout is a clock, and therefore has no BS cell
          LPIn: in bit;
          LPOut, ProcClkOut: out bit;
          ProcSpeed: in bit_vector (0 to 2);
          ResetRespOut: out bit;
          notRST, CPUReset, CPUAnalyse: in bit;
          ErrorOut: out bit;
          ErrorIn: in bit;
          DebugOut: out bit_vector (0 to 7);
          DebugIn: in bit;
          Interrupt: in bit_vector (0 to 7);
          MemAddr: out bit_vector (2 to 31);
          MemData: inout bit_vector (0 to 31);
          notMemRd: out bit;
          MemReq: in bit;
          MemGranted, MemRefPend, notMemRf: out bit;
          MemWait: in bit;
          notMemCAS, notMemRAS, notMemPS, notMemBE: out bit_vector (0 to 3);
          BootSrce: in bit_vector (0 to 1);
          DisableRAM: in bit;
          LinkIn: in bit_vector (0 to 3);
          LinkOut: out bit_vector (0 to 3);
          Link0Special: in bit;
          LinkSpeed: in bit_vector (0 to 1);
          EventReq: in bit;
          EventAck: out bit;
          EventWaiting: linkage bit;
          -- This output has no BS cell due to a bug
          TDI: in bit;
          TDO: out bit;
          TMS, TCK, notTRST: in bit;
MirrorADDEMI: in bit );

use STD_1149_1_1990.all;

attribute PIN_MAP of ST20450A : entity is PHYSICAL_PIN_MAP;

constant PQFP208: PIN_MAP_STRING :=

"memaddr: (3,4,5,8,9,10,13,14,15,18,19,20,23,24,25,29,30,31,34,35,36,39,40,41,44,45,46, 49,50,51)," &

"memdata: (54,55,56,57,59,60,61,62,64,65,66,67,69,70,71,72,74,75,76,77,80,81,82,83,85,8 6,87,88,90,91,92,93)," &

"debugout: (95,96,97,98,100,101,102,103)," &

"debugin:106," &

"errorin:107," &

"errorout:108," &

"notrst:109," &

"resetrespout:111," &

"cpuanalyse:112," &

"cpureset:113," &

"bootsrce: (114,116)," &

"tdi:117," &

"tms:118," &

"tck:119," &

"nottrst:121," &

"tdo:122," &

"interrupt: (123,124,126,127,128,129,132,133)," &

"ipclockos:137," &

"ipclockin:138," &

"ipin:139," &

"ipout:140," &

"procspeed: (142,143,144)," &

"clockin:145," &

"linkclockin:147," &

"linkspeed: (148,149)," &

"link0special:150," &

"eventreq:152," &

"eventack:153," &

"eventwaiting:154," &

"linkin: (158,160,163,165)," &

"linkout: (159,161,164,166)," &

"mirroraddemi:169," &

"disableram:170," &

"notmemrd:171," &

"memreq:173," &

"memgranted:174," &

"memrefpend:175," &

"memwait:176," &

"notmemrf:178," &

"procclkout:180," &

"notmembe: (184,185,186,187)," &

"notmemps: (190,191,192,195)," &

"notmemcas: (196,197,200,201)," &

"notmemras: (202,205,206,207)," &
"vdd: (11,17,21,27,28,33,37,43,47,53,63,73,79,89,99,105,115,125,131,141,151,157,167,177,179,183,189,193,199,203)," &
"gnd: (2,6,12,16,22,26,32,38,42,48,52,58,68,78,84,94,104,110,120,130,136,146,156,162,172,182,188,194,198,204,208)," &
"spare: (134,135,155,168);

attribute TAP_SCAN_IN of TDI : signal is true;
attribute TAP_SCAN_MODE of TMS : signal is true;
attribute TAP_SCAN_OUT of TDO : signal is true;
attribute TAP_SCAN_CLOCK of TCK : signal is (10.0e6, BOTH);
attribute TAP_SCAN_RESET of notTRST: signal is true;

attribute INSTRUCTION_LENGTH of ST20450A : entity is 5;

attribute INSTRUCTION_OPCODE of ST20450A : entity is
"BYPASS (11111)," &
"EXTEST (00000)," &
"IDCODE (00001)," &
"SAMPLE (00010) " ;

attribute INSTRUCTION_CAPTURE of ST20450A : entity is "00001";

attribute IDCODE_REGISTER of ST20450A : entity is "000001010000000000000000010001";

attribute BOUNDARY_LENGTH of ST20450A : entity is 181;

attribute BOUNDARY_REGISTER of ST20450A : entity is
-- num cell port function safe [ccell disval rslt]
" 0 (BC_1, notmemras(3) , output2, X)," &
" 1 (BC_1, notmemras(2) , output2, X)," &
" 2 (BC_1, notmemras(1) , output2, X)," &
" 3 (BC_1, notmemras(0) , output2, X)," &
" 4 (BC_1, notmemcas(3) , output2, X)," &
" 5 (BC_1, notmemcas(2) , output2, X)," &
" 6 (BC_1, notmemcas(1) , output2, X)," &
" 7 (BC_1, notmemcas(0) , output2, X)," &
" 8 (BC_1, notmemps(3) , output2, X)," &
" 9 (BC_1, notmemps(2) , output2, X)," &
"10 (BC_1, notmemps(1) , output2, X)," &
"11 (BC_1, notmemps(0) , output2, X)," &
"12 (BC_1, notmembe(3) , output2, X)," &
"13 (BC_1, notmembe(2) , output2, X)," &
"14 (BC_1, notmembe(1) , output2, X)," &
"15 (BC_1, notmembe(0) , output2, X)," &
"16 (BC_1, procclkout , output2, X)," &
"17 (BC_1, * , internal, X)," &
"18 (BC_1, notmemrfr , output2, X)," &
"19 (BC_1, memwait , input, X)," &
"20 (BC_1, * , internal, X)," &
"21 (BC_1, * , internal, X)," &
"22 (BC_1, memrefpend , output2, X)," &
"23 (BC_1, * , internal, X)," &
"24 (BC_1, memgranted , output2, X)," &
"25 (BC_1, memreq , input, X)," &
"26 (BC_1, * , internal, X)," &
"27 (BC_1, * , internal, X)," &
"28 (BC_1, notmemrd , output2, X)," &
" 29 (BC_1, disableram , input, X)," &  
" 30 (BC_1, * , internal, X)," &  
" 31 (BC_1, mirroraddemi , input, X)," &  
" 32 (BC_1, * , internal, X)," &  
" 33 (BC_1, linkout(3) , output2, X)," &  
" 34 (BC_1, linkin (3) , input, X)," &  
" 35 (BC_1, linkout(2) , output2, X)," &  
" 36 (BC_1, linkin (2) , input, X)," &  
" 37 (BC_1, linkout(1) , output2, X)," &  
" 38 (BC_1, linkin (1) , input, X)," &  
" 39 (BC_1, linkout(0) , output2, X)," &  
" 40 (BC_1, linkin (0) , input, X)," &  
"-- " (BC_1, eventwaiting , output2, X)," &  
"-- no BS cell here due to bug  
" 41 (BC_1, eventack , output2, X)," &  
" 42 (BC_1, eventreq , input, X)," &  
" 43 (BC_1, link0special , input, X)," &  
" 44 (BC_1, linkspeed(1) , input, X)," &  
" 45 (BC_1, linkspeed(0) , input, X)," &  
" 46 (BC_1, linkclockin , input, X)," &  
" 47 (BC_1, clockin , input, X)," &  
" 48 (BC_1, procspeed(2) , input, X)," &  
" 49 (BC_1, procspeed(1) , input, X)," &  
" 50 (BC_1, procspeed(0) , input, X)," &  
" 51 (BC_1, lpout , output2, X)," &  
" 52 (BC_1, lpin , input, X)," &  
" 53 (BC_1, lpcclockin , input, X)," &  
" 54 (BC_1, interrupt(7) , input, X)," &  
" 55 (BC_1, interrupt(6) , input, X)," &  
" 56 (BC_1, interrupt(5) , input, X)," &  
" 57 (BC_1, interrupt(4) , input, X)," &  
" 58 (BC_1, interrupt(3) , input, X)," &  
" 59 (BC_1, interrupt(2) , input, X)," &  
" 60 (BC_1, interrupt(1) , input, X)," &  
" 61 (BC_1, interrupt(0) , input, X)," &  
" 62 (BC_1, bootsrce(0) , input, X)," &  
" 63 (BC_1, bootsrce(1) , input, X)," &  
" 64 (BC_1, cpureset , input, X)," &  
" 65 (BC_1, cpucoreanalyse , input, X)," &  
" 66 (BC_1, resetrespout , output2, X)," &  
" 67 (BC_1, notrst , input, X)," &  
" 68 (BC_1, errorout , output2, X)," &  
" 69 (BC_1, errorin , input, X)," &  
" 70 (BC_1, debugout , output2, X)," &  
" 71 (BC_1, debugout(7) , output2, X)," &  
" 72 (BC_1, debugout(6) , output2, X)," &  
" 73 (BC_1, debugout(5) , output2, X)," &  
" 74 (BC_1, debugout(4) , output2, X)," &  
" 75 (BC_1, debugout(3) , output2, X)," &  
" 76 (BC_1, debugout(2) , output2, X)," &  
" 77 (BC_1, debugout(1) , output2, X)," &  
" 78 (BC_1, debugout(0) , output2, X)," &  
" 79 (BC_1, memdata( 0) , input, X)," &  
" 80 (BC_1, memdata( 0) , output3, X, 87, 0, Z)," &  
" 81 (BC_1, memdata( 1) , input, X)," &  
" 82 (BC_1, memdata( 1) , output3, X, 87, 0, Z)," &  
" 83 (BC_1, memdata( 2) , input, X)," &  
" 84 (BC_1, memdata( 2) , output3, X, 87, 0, Z)," &
"85 (BC_1, memdata(3), input, X)," &
"86 (BC_1, memdata(3), output3, X, 87, 0, Z)," &
"87 (BC_1, input, X)," & -- mdata 0-7
"88 (BC_1, memdata(4), input, X)," &
"89 (BC_1, memdata(4), output3, X, 87, 0, Z)," &
"90 (BC_1, input, X)," &
"91 (BC_1, memdata(5), output3, X, 87, 0, Z)," &
"92 (BC_1, * , control, 0)," & -- mdata 8-15
"93 (BC_1, memdata(6), output3, X, 87, 0, Z)," &
"94 (BC_1, input, X)," &
"95 (BC_1, memdata(7), output3, X, 87, 0, Z)," &
"96 (BC_1, input, X)," &
"97 (BC_1, memdata(8), output3, X, 104, 0, Z)," &
"98 (BC_1, input, X)," &
"99 (BC_1, memdata(9), output3, X, 104, 0, Z)," &
"100 (BC_1, input, X)," &
"101 (BC_1, memdata(10), output3, X, 104, 0, Z)," &
"102 (BC_1, input, X)," &
"103 (BC_1, memdata(11), output3, X, 104, 0, Z)," &
"104 (BC_1, * , control, 0)," & -- mdata 16-23
"105 (BC_1, memdata(12), input, X)," &
"106 (BC_1, memdata(12), output3, X, 104, 0, Z)," &
"107 (BC_1, input, X)," &
"108 (BC_1, memdata(13), output3, X, 104, 0, Z)," &
"109 (BC_1, input, X)," &
"110 (BC_1, memdata(14), output3, X, 104, 0, Z)," &
"111 (BC_1, memdata(15), input, X)," &
"112 (BC_1, memdata(15), output3, X, 104, 0, Z)," &
"113 (BC_1, * , control, 0)," & -- mdata 24-31
"114 (BC_1, memdata(16), input, X)," &
"115 (BC_1, memdata(16), output3, X, 113, 0, Z)," &
"116 (BC_1, input, X)," &
"117 (BC_1, memdata(17), output3, X, 113, 0, Z)," &
"118 (BC_1, input, X)," &
"119 (BC_1, memdata(18), output3, X, 113, 0, Z)," &
"120 (BC_1, input, X)," &
"121 (BC_1, memdata(19), output3, X, 113, 0, Z)," &
"122 (BC_1, input, X)," &
"123 (BC_1, memdata(20), output3, X, 113, 0, Z)," &
"124 (BC_1, input, X)," &
"125 (BC_1, memdata(21), output3, X, 113, 0, Z)," &
"126 (BC_1, input, X)," &
"127 (BC_1, memdata(22), output3, X, 113, 0, Z)," &
"128 (BC_1, input, X)," &
"129 (BC_1, memdata(23), output3, X, 113, 0, Z)," &
"130 (BC_1, * , control, 0)," & -- mdata 24-31
"131 (BC_1, memdata(24), input, X)," &
"132 (BC_1, memdata(24), output3, X, 130, 0, Z)," &
"133 (BC_1, input, X)," &
"134 (BC_1, memdata(25), output3, X, 130, 0, Z)," &
"135 (BC_1, input, X)," &
"136 (BC_1, memdata(26), output3, X, 130, 0, Z)," &
"137 (BC_1, input, X)," &
"138 (BC_1, memdata(27), output3, X, 130, 0, Z)," &
"139 (BC_1, input, X)," &
"140 (BC_1, memdata(28), output3, X, 130, 0, Z)," &
"141 (BC_1, input, X)," &
"142 (BC_1, memdata(29), output3, X, 130, 0, Z)," &
" 143 (BC_1, memdata(30) , input, X)," &
" 144 (BC_1, memdata(30) , output3, X, 130, 0, Z)," &
" 145 (BC_1, memdata(31) , input, X)," &
" 146 (BC_1, memdata(31) , output3, X, 130, 0, Z)," &
" 147 (BC_1, memaddr( 2) , output3, X, 150, 0, Z)," &
" 148 (BC_1, memaddr( 3) , output3, X, 150, 0, Z)," &
" 149 (BC_1, memaddr( 4) , output3, X, 150, 0, Z)," &
" 150 (BC_1, * , control, 0)," & -- maddr 2-7
" 151 (BC_1, memaddr( 5) , output3, X, 150, 0, Z)," &
" 152 (BC_1, memaddr( 6) , output3, X, 150, 0, Z)," &
" 153 (BC_1, memaddr( 7) , output3, X, 150, 0, Z)," &
" 154 (BC_1, memaddr( 8) , output3, X, 160, 0, Z)," &
" 155 (BC_1, memaddr( 9) , output3, X, 160, 0, Z)," &
" 156 (BC_1, memaddr(10) , output3, X, 160, 0, Z)," &
" 157 (BC_1, memaddr(11) , output3, X, 160, 0, Z)," &
" 158 (BC_1, memaddr(12) , output3, X, 160, 0, Z)," &
" 159 (BC_1, memaddr(13) , output3, X, 160, 0, Z)," &
" 160 (BC_1, * , control, 0)," & -- maddr 8-15
" 161 (BC_1, memaddr(14) , output3, X, 160, 0, Z)," &
" 162 (BC_1, memaddr(15) , output3, X, 160, 0, Z)," &
" 163 (BC_1, memaddr(16) , output3, X, 164, 0, Z)," &
" 164 (BC_1, * , control, 0)," & -- maddr 16-23
" 165 (BC_1, memaddr(17) , output3, X, 164, 0, Z)," &
" 166 (BC_1, memaddr(18) , output3, X, 164, 0, Z)," &
" 167 (BC_1, memaddr(19) , output3, X, 164, 0, Z)," &
" 168 (BC_1, memaddr(20) , output3, X, 164, 0, Z)," &
" 169 (BC_1, memaddr(21) , output3, X, 164, 0, Z)," &
" 170 (BC_1, memaddr(22) , output3, X, 164, 0, Z)," &
" 171 (BC_1, memaddr(23) , output3, X, 164, 0, Z)," &
" 172 (BC_1, memaddr(24) , output3, X, 174, 0, Z)," &
" 173 (BC_1, memaddr(25) , output3, X, 174, 0, Z)," &
" 174 (BC_1, * , control, 0)," & -- maddr 24-31
" 175 (BC_1, memaddr(26) , output3, X, 174, 0, Z)," &
" 176 (BC_1, memaddr(27) , output3, X, 174, 0, Z)," &
" 177 (BC_1, memaddr(28) , output3, X, 174, 0, Z)," &
" 178 (BC_1, memaddr(29) , output3, X, 174, 0, Z)," &
" 179 (BC_1, memaddr(30) , output3, X, 174, 0, Z)," &
" 180 (BC_1, memaddr(31) , output3, X, 174, 0, Z);"