

## PRELIMINARY DATA October 1988

The WEITEK XL-8236 is a fullyintegrated CMOS 22-bit raster code sequencer. It is used with the WEITEK XL-8237 32-bit raster image processor to make the HyperScript-Processor™, a highperformance graphics CPU capable of driving raster printers at up to 60 pages per minute. WEITEK's single-precision floating point unit may also be used to produce a tightly-coupled raster image printing system.



| Contents                  |           |
|---------------------------|-----------|
| Features                  | 1         |
| Description               | 1         |
| Block Diagram             | 2         |
| Signal Description        | 3         |
| Architecture              | 5         |
| Stack                     | 6         |
| Registers                 | 7         |
| Neutralization            | 9         |
| STALL-                    | 10        |
| Interrupts                | 10        |
| RESET-                    | 18        |
| Instruction Set           | 19        |
| Instruction Interaction   | 57        |
| OP Output Bus Operation   | 61        |
| Development Tools         | 63        |
| Design Requirements       | 63        |
| Ratings and DC Specificat | ions 64   |
| AC Specifications         | 65        |
| Timing Description        | 66        |
| I/O Characteristics       | 68        |
| Pin Configuration         | 69        |
| Physical Dimensions       | 70        |
| Ordering Information      | 71        |
| Revision Summary          | 71        |
| Index                     | 72        |
| Documentation Request Fo  | orm 75    |
| Sales Offices ba          | ack cover |
|                           |           |



The masters for this document were printed on an XL-8200 development system

XL-8236 Raster Code Sequencer Data Sheet October, 1988

Copyright ©WEITEK Corporation 1988 All rights reserved

WEITEK Corporation 1060 East Arques Avenue Sunnyvale, California 94086 Telephone (408) 738-8400

WEITEK is a trademark of WEITEK Corporation

PostScript is a registered trademark of Adobe Systems, Incorporated BITSTREAM and FontWare are trademarks of BITSTREAM Corporation UNIX is a trademark of AT&T Bell Laboratories XENIX and MS-DOS are trademarks of Microsoft Corporation NIMBUS is a registered trademark of URW Corporation

WEITEK reserves the right to make changes to these specifications at any time

Printed in the United States of America 90 89 88 6 5 4 3 2 1

### PRELIMINARY DATA October 1988

### Features

22-BIT SINGLE-CHIP SEQUENCING UNIT

22-bit code address bus 32-bit data address bus  $33 \times 32$ -bit on-chip stack

#### HIGH PERFORMANCE

10 to 60 page per minute with WEITEK's HyperScript interpreter Low-power CMOS with TTL-compatible I/O

POWERFUL DEVELOPMENT TOOLS

PostScript-compatible interpreter C compiler Graphics development system

### Description

The XL-8236 is a high-performance 22-bit raster code sequencer (RCS). The XL-8236 combines with its companion chip, the XL-8237 raster image processor (RIP), to make the XL-8200 HyperScript-Processor, a cost-effective graphics CPU for raster printing applications over a wide performance range. The most typical use of a HyperScript-Processor is in a PostScript-language laser printer.

HyperScript-Processors are graphics RISC processors that combine Harvard architecture, single-cycle instruction execution, and specialized math and bit manipulation functions to make a high-speed grapics processor, capable of interpreting the complex Post-Script language on high-speed printers. The XL-8236 provides instruction sequencing and other control func-

**BUILT-IN REGISTERS AND TIMERS** 

TRAP AND INTERRUPT HANDLING

Breakpoint register

Status register

System reset

32-bit programmable timer

Three external interrupt lines

Five internal exceptions

The XL-8236 is a CMOS device offering high performance and low power consumption, with TTL-compatible I/O. It is available in a standard 145-pin ceramic or plastic PGA (Pin Grid Array) package.

tions. The XL-8237 provides data addressing, arithme-

tic, logical, and bit-manipulation fuctions.



Figure 1. Simplified block diagrams

© Copyright WEITEK 1988 All rights reserved

# **Block Diagram**



Figure 2. Block diagram

## **Signal Description**

### C BUS

The  $C_{31..0}$  code input bus is driven by the code memory with the 32-bit instruction word. The code word is latched by the RCS at the rising edge of the clock. Because it contains a built-in pipeline register, it is not necessary to use an external pipeline register between code memory and the XL-8236.

### AC BUS

The  $AC_{21..0}$  code address output bus is driven by the program sequencing unit. It sends a 22-bit instruction address to the code memory. The code address is not latched by the RCS, so an external address latch is needed between the AC bus and code memory.\* Unused high-order bits of the AC bus can be left floating.

The AC bus is driven on every cycle (even when STALL-, or NEUT- are asserted) unless disabled with the OEAC- signal.

The AC bus produces instruction addresses, not byte addresses.

### AD BUS

The  $AD_{31..0}$  data address bus provides addresses for data memory operations (the data is transferred over the D bus to the RIP). It is also used for intra-processor communication. It connects the integer processing unit to the sequencer. The AD bus can also be used as a bidirectional data bus for transfers to and from other hardware.

All 32 bits of the AD bus need to be attached between the RCS and RIP to allow intra-processor data transfer. This traffic may take place during STALL- or NEUT cycles, and it is important that it not be interfered with. If any external device wishes to write to memory asynchronously to the XL-Series devices, it must not write directly to the AD bus.

Addresses on the AD bus are byte addresses.

#### OP BUS

The  $OP_{4..0}$  output bus indicates the type of instruction that is executing, and can be used to control external

hardware. The memory system must decode the OP bus outputs to determine when to read, when to write, and when to latch the data address. In addition, fifteen of the 32 OP combinations are used to signal loads or stores to "external registers" 0-14, which can be any external hardware. These external register transfers take place over the AD bus.

### EXT1-, EXT2-, and EXT4-

Level-sensitive interrupt request inputs. The current instruction is allowed to complete and execution proceeds from one of the interrupt vectors. External interrupts can be enabled and disabled in the sequencer status register. Interrupt signals are examined at the rising edge of the clock.

EXT4- is used as a floating point exception interrupt in systems with the XL-3232 FPU.

There is no EXT3-.

Interrupt signals must be held until acknowledged.

#### RESET-

A level-sensitive input that resets the sequencer and causes a branch to address 0. The sequencer status register is initialized as described on page 18. The other registers in the chip are undefined. Registers that can cause exceptions (such as the timer and breakpoint registers) must be initialized before their exceptions are enabled.

Reset is not useful as a non-maskable interrupt.

#### CLK

The Clock input, CLK, is a single-phase TTL-level clock signal.

#### NEUT-

2

NEUT- (neutralize) is an output signal that goes from the RCS to the RIP and FPU. It is not normally used by hardware outside the processor chip set. NEUT- is asserted by the sequencer, and instructs all XL devices to cancel their current instructions. This is done on transfer-of-control instructions (including branches, calls, and interrupts) to prevent the instruction in the pipeline from being executed. All XL-Series chips must have their NEUT- lines tied together.

<sup>\*</sup> Note that a latch, not a register, should be used. Future versions of the XL-8236 may contain an on-chip address latch.

## Signal Description, continued

## STALL-

STALL- is a "not-ready" input line that causes the current code fetch to be retried on the next cycle. The instruction that was to be executed on the next cycle is canceled (but the current instruction is allowed to complete). STALL- is typically used by the code memory subsystem when the requested code word cannot be read in the current cycle.

The XL chips each cancel their currently fetching instruction, and fetch the instruction again on the next cycle, and on every cycle that STALL- is asserted. The fetched instruction will be executed when STALL- is de-asserted.

All the XL-Series chips must have their STALL- lines tied together.

## COND

Condition code input. Goes from the RIP to the RCS. Not normally used outside the processor chip set.

### FPCN

Floating point condition code input. This signal goes from the floating point processor to the RCS. In sys-

tems without a floating point processor FPCN is tied to ground.

### OEAD-

OEAD- is an asynchronous output enable signal for the AD bus. The bus is at a high-impedance state when disabled.

## VCC AND GND

VCC is a +5.0 volt supply. GND is a system ground. All VCC and GND pins must be connected—floating pins are not allowed.

### NC

No connection (must be left floating). Reserved for future expansion.

## TIE HIGH

This signal line is reserved for future expansion. It should be tied to VCC.

## TIE LOW

This signal line is reserved for future expansion. It should be tied to GND.

#### PRELIMINARY DATA October 1988

### Architecture

### BUSES

The XL-8236 uses three buses: the C bus (32 bits), the AC bus (22 bits), and the AD bus (32 bits). The AC (code address) bus is used to address code memory. The AD (data address) bus can be used to transfer data between the RCS registers and the rest of the system, including the XL-8237 RIP, and to save and restore the stack externally. The XL-8237 RIP also uses this bus as a data address bus. The C (code) bus provides the instructions for both the RCS and the RIP.

#### PIPELINING

The XL-8236 instruction sequence is pipelined. In each clock cycle, the next instruction is fetched while the current instruction is being executed. This parallel fetch/execute architecture allows faster execution than the usual sequential fetch/execute architecture.

#### INSTRUCTION SET

The instruction set contains branch, conditional branch, subroutine call and return, software interrupt and interrupt return, loop control, and coprocessor control instructions.

#### INTERRUPT CONTROL

There are three external interrupt lines, plus reset. Interrupts can be masked individually and collectively, with the individual interrupt enable and master interrupt enable bits in the sequencer status register.

Interrupts are vectored to one of fifteen addresses.

#### MEMORY CONTROL

The RCS's memory interface is controlled by the STALL- input.

STALL- is used to cancel instructions in the event of delayed code memory word. It is typically used with dynamic RAM and memory caches. External hardware detects memory faults and asserts STALL- until the data is available.

In addition to these two input signals, the RCS has a five-bit OP output bus. The OP bus identifies the current state of the memory interface.

### CONTROL FLOW

Figure 3 shows the major states of the system: at power-up, at reset, and in applications programs.

## Architecture, continued



Figure 3. Major states of an XL-Series system

## Stack

The RCS has a 33-word-deep by 32-bit-wide register file addressed as a stack. The stack may contain loop counts, branch addresses, and subroutine return addresses. The stack consists of a 32-bit top-of-stack register (.tos), a 32-word by 32-bit register file, and a stack pointer, which is a 5-bit field within the sequencer status register (.ssr).

On reset, the stack pointer is initialized with all 1's (a value of 31), indicating an empty stack. The stack pointer is a modulo-32 counter which increments before each push and decrements after each pop.

Stack underflow and overflow exceptions are provided. An underflow exception occurs when a pop operation nearly empties the stack. An overflow exception is generated when a push operation nearly fills the stack. (For more details, see sections *Stack Overflow* and *Stack Underflow* on page 15.)

A pair of exception routines can implement a larger stack in system memory. When the RCS stack overflows, it is copied to the main memory stack; when it underflows, data in the memory stack is restored to the RCS stack.

PRELIMINARY DATA October 1988

## Registers

## FETCH AND EXECUTION ADDRESS REGISTERS

The sequencer fetches an instruction on every cycle, and executes it on the following cycle. The instruction cancellation mechanism allows the results of an instruction to be discarded after the instruction has completed, effectively turning the instruction into a no-op, but the chip is never idle.

The currently executing address (.cea) register is a 22-bit register containing the address of the instruction currently being executed. This is the instruction that was fetched on the previous cycle.

The currently fetching address (.cfa) register is a 22-bit register containing the address of the instruction being fetched. This instruction will be executed on the next cycle, and the address in the .cfa will be copied into the currently executing register (.cea).

### INTERRUPT ADDRESS REGISTERS

The two interrupt address registers are the interrupt fetch address (.ifa) and the interrupt execute address (.iea). The RCS stores interrupt return addresses in these registers. (For more details see *Interrupt Sequence* on page 10.)

## SEQUENCER STATUS REGISTER

The sequencer status register (.SSr) is a 32-bit register containing state information. The upper five bits contain the stack pointer. The remaining bits include branch bits, nine sets of flag/enable bits which control and identify the state of interrupts and exceptions, and the master interrupt enable bit. If the *master enable bit* (men) is cleared, all interrupts are prevented from executing.

Several instructions implicitly use or alter information in the .ssr. The .ssr is illustrated in Figures 4 and 5.

The b and bi bits are state bits. The b bit indicates that the previous instruction was a taken branch. The bi bit stores the current values of the b bit for interrupt processing.

The nine sets of flag/enable bits selectively control the interrupt mechanism. If the enable bit is set, and if the indicated exception occurs, an interrupt occurs and the associated flag bit is set. Interrupt-handling software reads this word and examines the flag bits to determine which interrupts have occurred. If either the master or individual interrupt enable is false and an interrupt occurs, no interrupt routine will be called, but the associated exception flag will still be set.

The flag bits are "sticky" — they will remain set even if the signal that sets them goes away. The bits can only be cleared by overwriting the .ssr. If a flag bit is set when its interrupt is disabled, it will *not* cause an interrupt when the interrupt is re-enabled. Thus, all pending interrupts must be handled before exiting the interrupt handler. Furthermore, the interrupts that have been serviced must have their flag bits reset before interrupts are re-enabled (or before the interrupt handler is exited) to assure proper operation of the sequencer.

External interrupts (EXT1-, EXT2-, and EXT4-) must be latched externally until acknowledged.

The five-bit top-of-stack (`.tos) pointer is part of the .ssr.

After a reset, the .ssr is initialized with all zeros except for the s bit, which is set; and the .tos field, which is set to all ones to indicate an empty stack.

### MODIFYING THE SSR

The .ssr can be read or written as a 32-bit register using the *Intrasystem Data Transfer Instructions* on pages 46-48. While the .ssr can be examined at any time, special care must be exercised when setting it to avoid losing interrupts.



Figure 4. Sequencer status register (.ssr)

## **Registers**, continued

In order to set or reset a portion of the .ssr, a readmodify-write sequence must be performed, that is, the .ssr is read into the RIP, the desired bit manipulation is performed and the .ssr is written with the new value. In order to avoid losing crucial state information and any interrupts that occurred between reading and writing the .ssr, the following rules must be followed:

- 1. Interrupts should be disabled (that is, the .ssr's men bit should be zero) with a trapi instruction. See pages 16-17.
- 2. Interrupts from external devices should be held until explicitly acknowledged by the interrupt handler software.
- 3. No internal interrupt, except timer interrupts, should occur.

## TIMER REGISTER AND INTERRUPT

The RCS includes a programmable timer based on a 32-bit timer register. The timer register contains a

signed 32-bit number whose value represents the number of clock cycles remaining until a timer interrupt occurs. The timer register is decremented during every clock cycle. Whenever the value is negative, the timer flag is set, allowing a timer interrupt occur.

The timer will continue to decrement even when negative. This allows accurate timing if the service routine is interrupted or delayed.

### BREAKPOINT REGISTER

The XL-8236 also includes a 32-bit breakpoint register (.brk), used to provide a code breakpoint for program development. A code address can be loaded into the .brk register. If the .ssr brkenc bit is set, any attempt to fetch the instruction located at the address loaded in the .brk register sets its breakpoint interrupt flag, generating a code-break interrupt if enabled.

| Symbol | Bit # | Meaning | I                                                                                                 |
|--------|-------|---------|---------------------------------------------------------------------------------------------------|
| -      | 0     | -<br>-  | reserved: must be set to zero<br>reserved: must be set to zero                                    |
| b      | 23    | b<br>bi | last instruction was a taken branch<br>last instruction of interrupted process was a taken branch |
| S      | 4     | s       | reserved: must be set to one                                                                      |
|        | 5     | si      | reserved: must be set to one                                                                      |
| brk    | 6     | brkflg  | flag for breakpoint interrupt                                                                     |
|        | 7     | brkenc  | enable for code breakpoint interrupt                                                              |
|        | 8     | -       | reserved: must be set to zero                                                                     |
| tim    | 9     | timflg  | flag for timer interrupt                                                                          |
|        | 10    | timen   | enable for timer interrupt                                                                        |
| SOV    | 11    | sovflg  | flag for RCS stack overflow interrupt                                                             |
|        | 12    | soven   | enable for RCS stack overflow interrupt                                                           |
| sun    | 13    | sunfig  | flag for RCS stack underflow interrupt                                                            |
|        | 14    | sunen   | enable for RCS stack underflow interrupt                                                          |
| trp    | 15    | trpflg  | flag for trap instruction interrupt                                                               |
|        | 16    | trpen   | enable for trap instruction interrupt                                                             |
| prv    | 17    | prvflg  | reserved: must be set to zero                                                                     |
|        | 18    | -       | reserved: must be set to zero                                                                     |
| ext4   | 19    | ext4flg | flag for external interrupt 4                                                                     |
|        | 20    | ext4en  | enable for external interrupt 4                                                                   |
| ext23  | 21    | ext23en | enable for external interrupt 2                                                                   |
|        | 22    | ext2flg | flag for external interrupt 2                                                                     |
|        | 23    | -       | reserved: must be set to zero                                                                     |
| ext1   | 24    | ext1flg | flag for external interrupt 1                                                                     |
|        | 25    | ext1en  | enable for external interrupt 1                                                                   |
| men    | 26    | men     | master interrupt enable                                                                           |
| .tos   | 31-27 | .tos    | five-bit top-of-stack pointer                                                                     |

Figure 5. Bit fields in the sequencer status register

PRELIMINARY DATA October 1988

## Neutralization

The XL-8236 RCS and its companion, the XL-8237 RIP, achieve high speed by simultaneously fetching the next instruction while executing the current instruction. When a branch is executed, the RCS already has the instruction following the branch in its instruction pipeline. This instruction is called the "shadow instruction." Fetching the instruction at the branch address takes an additional cycle, since it's not yet in the pipeline, so the destination instruction is executed after a one-cycle delay. This is called "delayed branching".

The XL-8236 provides a neutralization output line, NEUT-. It can selectively cancel the effects of the shadow instruction, effectively replacing it with a noop. The XL-8236 instruction set normally sets NEUTactive after branch, call and return instructions (including interrupt calls and returns), thereby canceling the shadow instruction. This allows the programmer to ignore the effects of delayed branching.

Neutralized instructions actually run to completion, but their results are discarded at the end of the cycle. Registers, status flags, and so on are simply not updated, so internal effect is as if the instruction was never executed.

The XL-8236 instruction set also provides three additional instructions which allow the shadow instruction to be executed: override neutralization (ovneut), override and increment stack pointer (ovneuti), and reverse neutralization (revneut). Efficient code makes use of these instructions to selectively execute shadow instructions, saving up to one clock cycle per branch.



Figure 6. Neutralization

## STALL-

The XL-8236 has a control input, STALL-, which directs the RCS and RIP to cancel the effects of the next instruction. This signal is asserted by external hardware when unable to complete a bus transfer in time, such as during a cache miss or refresh cycle. An active STALL-signal cancels the next instruction. Instructions canceled through this mechanism are refetched and will be re-executed when the STALL- signal is de-asserted.

Cancelled instructions actually run to completion, but their results are discarded at the end of the cycle. Registers, status flags, and so on are simply not updated, so internal effect is as if the instruction was never executed.

STALL- allows the current instruction to complete, but cancels the next instruction. The most common use of STALL- is to re-execute an instruction fetch on a wait state, cache miss, or refresh cycle. The invalid word loaded on the STALL-ed cycle is released, then the instruction is executed and normal execution continues.



Figure 7. Effects of STALL-

## Interrupts

The XL-8236 can receive interrupts from three external sources: EXT1-, EXT2-, and EXT4- (there is no EXT3); and can generate five interrupts internally: BRK, TIM, SOV, SUN, and TRP. When an interrupt control line or internal condition becomes active, the RCS sets the corresponding .ssr interrupt flag. If the master interrupt enable (men) bit of the .ssr is set, and the corresponding .ssr interrupt enable is active, the interrupt will be honored, as described below.

There are fifteen interrupt vector addresses. All external interrupt lines are level-sensitive. They are sampled at the rising edge of the clock.

### INTERRUPT SEQUENCE

When an interrupt is detected, the .cfa is stored in the iea, and the next fetch address is placed in the .ifa. This sequence allows the system to return to the next instruction (.cfa) on an interrupt return. See figure 8.

The RCS then neutralizes the fetched instruction and branches to the interrupt vector address. The old value of the .ssr b bit is saved in the bi bit.

The interrupt vectoring scheme is based on four classes of interrupts. When an interrupt request is approved, the RCS branches to the address formed by or-ing the 32-bit interrupt base address register (.ibr) with the four interrupt classes as shown in figure 12. This gives the capability of up to 15 different vector addresses (not 16 because at least one class bit must be non-zero for an interrupt to occur).

Note that if multiple interrupts occur simultaneously, they are not prioritized. Rather, the vector address of the interrupt handler is selected to indicate which interrupt classes are pending.

Interrupts can be nested to any depth by saving the contents of the .iea, .ifa and .ssr registers externally.

### **RETURNING FROM INTERRUPTS**

To return from an interrupt, two special interrupt return instructions must be executed, return-from-interrupt-0 (rfi0) and return-from-interrupt-1 (rfi1). Executing rfi0 returns the .iea register to the .cfa register places the contents of the .iea register onto the AC bus and enables the interrupt master enable bit (men). The upadating of the men bit may occur on the cycle in which the rfi0 is executed, or one cycle after that. Executing rfi1 returns the .ifa to the .cfa and places the .ifa register contents onto the AC bus, restoring the RCS state to what it was before the interrupt was requested.

PRELIMINARY DATA October 1988

## Interrupts, continued



Figure 8. Normal interrupt entry sequence

Note that the enabling of the men bit during the rf10 cycle allows an interrupt to be acknowledged before the rfi1 instruction executes, causing the state of the machine to be lost. Rfi0 also ignores the state of STALL-. Two steps must be taken to avoid this from causing trouble:

- 4. Condition C13 by ANDing it with STALL-, as shown in figure 9. This will prevent the RCS from ever seeing an rfi0 instruction during STALL- cycles, and eliminates the problem (that it alters the code word is unimporant, since the STALL- signal will cause it to not be executed). If your design does not use STALL-, you do not need to implement this.
- 5. Use the code in figure 10 at the start of your interrupt routine to test for improper interrupt exit se-

quences and to restore the state correctly. This step must be implemented whether you use STALL- or not.



Figure 9. Hardware portion of the special handling for rfi0/rfi1

### Interrupts, continued

```
/* Beginning of interrupt handler */
/*
       This routine works by testing the value of .iea against the address of the interrupt
       handler's rfi1 instruction. This implementation assumes that there is only one exit routine;
       that is, that there is only one rfi1 instruction in the whole system.
       The extra overhead consists only of a few instructions, since the interrupt calls are not
       spurious; they simply happened a cycle too soon.
       This example is written in a pseudo-code that mixes C and XL assembly code. */
swap register banks
if (.iea == rfi1_addr) {
       /* This interrupt came between rfi0 and rfi1. Restore the state of the previous call, with
           a few exceptions ... */
       saved ssr.bi = .ssr.bi;
} else {
       /* This is a normal interrupt call. Save .iea, .ifa, and .ssr specially */
       saved lea = .lea;
       saved ifa = .ifa;
       saved ssr = .ssr;
}
/* Main part of interrupt handler */
/* End of interrupt handler */
.iea = saved iea;
.ifa = saved ifa;
.ssr = saved_ssr;
rfi0;
rfi1_addr:
rfi1; asrtadr
```

Figure 10. Software portion of the special handling of rfi0 and rfi1

## INTERRUPTS AND STALL-

Interrupt processing takes precedence over stalls: if STALL- is asserted and an enabled interrupt is approved, the RCS will honor the interrupt and perform the interrupt entry sequence. (See figure 11). Because the AC bus address changes (the only situation when it

can change with STALL- asserted), designers using variable-latency code memory subsystems must handle this case. This is described in detail in the *XL-Series* Hardware Designer's Guide.

PRELIMINARY DATA October 1988

## Interrupts, continued









## INTERRUPT FLAG BITS

The interrupt flag bits record the history of the associated interrupt. If the interrupt was asserted at any time in the past, then the flag bit will be set even if the enable is not set (except for the breakpoint register;

breakpoint comparisons are only performed if the associated enable bit is set). Once the flag bit is set it can only be cleared by writing an entire word into the .ssr.

### Interrupts, continued

#### EXTERNAL INTERRUPT SOURCES

The external interrupt sources are: EXT1-, EXT2-, and EXT4-. Each has status and interrupt enable bits in the .ssr.

The EXT1- control line is a dedicated external interrupt. Its interrupt mask bit in the .ssr is ext1en. Its status bit is ext1flg.

The EXT2- interrupt line has an enable bit, ext23en. Its status bit is ext2flg.

EXT4- is typically used to signal exception conditions from floating point processors, but can be used as a general-purpose interrupt. Its enable bit is ext4en, and its status flag is ext4flg.

#### INTERNAL INTERRUPT SOURCES

The five internal interrupt sources (SOV, SUN, TRP, TIM, and BRK) each have a status and interrupt enable bit in the .ssr.

SOV and SUN indicate stack near-overflow and nearunderflow. SOV occurs when data is pushed into the third-to-last available word on the stack (.tos = 29). SUN occurs when the stack is empty or nearly empty (.tos = 1 or .tos = 0, or .tos = 31). The enable and status bits for SOV and SUN are soven, sovflg, sunen, and sunflg, respectively.

Note that the stack underflow exception can occur at more than one stack position. The stack pointer (the .tos field) must be used to determine the stack position in exception handling, rather than using constants showing the stack position at which you expect the exception to occur.

TRP is set by invoking the trap instruction. Its enable and status bits are trpen and trpflg, respectively.

The remaining two exceptions, TIM and BRK, are set on timer interrupts and breakpoints, respectively. Their enable and status bits are timen, timflg, brkenc, and brkflg.

### BREAKPOINT FACILITY

The breakpoint (.brk) register provides a facility to interrupt normal program execution when a specific instruction is executed (breakpoint).

See figure 13 for the timing of a code breakpoint. The system stops *before* executing the instruction referenced by the .brk register. Note that even instructions which are to be neutralized will cause a code breakpoint. This allows simple single-stepping of the system by setting the breakpoint to the .ifa register (the "next" instruction to be executed).

Breakpoints are not reliable if they occur on addresses that are executed *after* shadow instructions, such as branch targets.



Figure 13. Code breakpoint timing

## Interrupts, continued

#### STACK OVERFLOW

The sovflg bit of the .ssr is set when the .tos field contains a 29 and a stack push operation is performed. If the stack overflow interrupt is enabled (soven = 1 and men = 1), then it will be detected during the cycle after the completion of the push operation. See figure 14 for details.

### STACK UNDERFLOW

The sunfig bit of the .ssr is set when the .tos field contains a 1, or 0, or 31 and a stack pop operation is performed. If the stack underflow interrupt is enabled (sunen = 1 and men = 1), then it will be detected either one or two cycles after the completion of the pop operation. (The extra cycle of delay doesn't cause problems because the exception is triggered when the next-to-last word is popped off the stack. Even if another pop occurs in the cycle between the first pop and the assertion of the exception, the data popped off will still be valid.) See figure 14 for details.

The stack should be initialized after a reset by pushing two values onto the stack. This will move it past the point where the stack underflow interrupt occurs.



Figure 14. Stack overflow/underflow timing. Note that the underflow may be signaled on one of two cycles.

## Interrupts, continued

### TRAPS

Software interrupts on the XL-8236 are called *traps*. They are invoked with the trapi instruction.

Traps are used primarily for system calls. The programmer would specify a system call by using the immediate field of the trap instructions, as in "trapi 47." This would push the number 47 onto the stack and cause a trap interrupt. The trap handler would use the value on the stack as a parameter.

### HANDLING INTERRUPTS

The software that handles interrupts should follow the procedure given in figure 15. The handler for nested interrupts is more complex. This is shown in figure 16 (detail in steps common to both figures is skimpy in figure 16, so be sure to read both).

Each flag bit in the .ssr must be reset after the interrupt or exception is serviced.



Figure 15. Description of interrupt handling

PRELIMINARY DATA October 1988

### Interrupts, continued



Figure 16. Nested interrupts

# RESET

Activating the RESET- line at the end of the clock cycle initializes the .ssr according to Figure 17, sets the .cfa register to zeros and sends the value zero out on the AC bus, forcing a branch to address zero. Figure 18 shows detailed reset timing. The user should place a no-op instruction in location zero.

|    |   | .tos | 3 |    |    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   | s |   |   |   |   |
|----|---|------|---|----|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 1  | 1 | 1    | 1 | 1  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |
| 31 |   |      |   | 27 | 26 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   | 5 | 4 | 3 |   |   | 0 |

Figure 17. Sequencer status register, initialized



Figure 18. Reset timing

## Instruction Set

## TERMS AND SYMBOLS

The instructions are listed on pages 20 and 21, then described in detail on the following pages. Each de-

scription includes a pseudo-code definition of the instruction. The following symbols are used:

| 1        | Concatenate fields. abc    def<br>gives abcdef.<br>Indicates that operations sepa-<br>rated by this symbol occur in<br>parallel. | COND { } % ixs [310] | Condition Code<br>Begin and end comment<br>Shift left by ixs bits<br>Specifies the bit field from bit |
|----------|----------------------------------------------------------------------------------------------------------------------------------|----------------------|-------------------------------------------------------------------------------------------------------|
| a dup b  | Duplicate b a times. 3 dup 0 gives 000.                                                                                          |                      | 31 to bit 0, inclusive. For example, reg (ra) [30] gives the lower four bits of register              |
| stack(t) | Location t in the sequencer stack                                                                                                |                      | ra.                                                                                                   |



### INSTRUCTION FORMAT

The XL-8236 uses two instruction formats: short and long. Short instructions use the upper 8 bits of a 32-bit instruction; the remaining bits are used as the instruction field for the XL-8237 RIP or a coprocessor. Short instructions include neutralization control, short branches with a 5-bit displacement and branching from a 32-bit displacement on the stack.

tions are used to provide bus transfer and housekeeping control operations, in addition to 24-bit and 28-bit subroutine and branch immediates.

Coprocessor instructions are reserved for future expansion, with the exception of the coprocessor load/store instructions, which are used in the XL-8232 to load and store the graphics floating point unit.

Long instructions are 32 bits long, with a format recognized by the RIP as a RCS operation. These instruc-

| Field               | Meaning                                           |
|---------------------|---------------------------------------------------|
| ra                  | selects ra register (of processor)                |
| imm11, imm24, imm28 | 11, 24, or 28 bit immediate                       |
| c                   | condition polarity select                         |
| imm5                | 5-bit signed or unsigned immediate                |
| ext1, ext2          | operation code extensions                         |
| rd                  | selects rd register (of processor or coprocessor) |
| extn                | external register number n                        |

Figure 20. Instruction fields



Figure 21. Instruction formats

# Instruction Format, continued

| Opertions                                          |             |             |             | Detailed<br>Description<br>Page # |
|----------------------------------------------------|-------------|-------------|-------------|-----------------------------------|
| Continue                                           | 000 00110   | BIP/co      | processor   | 22                                |
| Cont                                               |             |             |             |                                   |
| Branch                                             | 000 00010   |             | nm24        | 7 24                              |
| Branch                                             |             | <u> </u> in | 111124      | 24                                |
| Short branch                                       | 100 imm5    | RIP/co      | processor   | 25                                |
| Branch to stack and pop                            | 000 01110   | RIP/co      | processor   | 26                                |
| Short forward branch on condition                  | 01 c imm5   | RIP/co      | processor   | 27                                |
| Loop Control                                       |             |             |             |                                   |
| Loop enter                                         | 000 00111   | RIP/co      | orocessor   | 29                                |
| Absolute branch to stack or or pop on condition    | 000 01 c 00 | RIP/co      | processor   | 30                                |
| Decrement stack and branch or pop if zero          | 000 00001   | in          | 1m24        | 31                                |
| Decrement stack and backward branch or pop if zero | 001 imm5    | RIP/coj     | processor   | 32                                |
| Branch and pop (loop exit)                         | 000 00011   | irr         | 1m24        | 33                                |
| Subroutine Control                                 |             |             |             | _                                 |
| Subroutine call                                    | 0001        | in          | 1m28        | 35                                |
| Subroutine return                                  | 000 01101   | RIP/co      | processor   | 36                                |
| Interrupt Control                                  |             |             |             |                                   |
| Return from interrupt 0                            | 00000000    | x           | 00101 x     | 38                                |
| Return from interrupt 1                            | 000 00100   | RIP/cop     | processor   | 39                                |
| Тгар                                               |             |             |             | i                                 |
| Trap immediate                                     | 00000000    | 11 x        | 00010 imm11 | 40                                |
| Neutralization                                     |             |             |             |                                   |
| Override neutralization                            | 000 01011   | RIP/coj     | orocessor   | 43                                |
| Override neutralization of subroutine call shadow  | 000 01111   | RIP/cop     | processor   | 44                                |
| Reverse neutralization                             | 000 00101   | RIP/co      | processor   | 45                                |
|                                                    |             |             |             |                                   |

**PRELIMINARY DATA** October 1988

٦

# Instruction Format, continued

| ntrasystem Data Transfer Inst                   | ruction  | s          |             |     |                                       |      | Detaileo<br>Descripti<br>Page # |
|-------------------------------------------------|----------|------------|-------------|-----|---------------------------------------|------|---------------------------------|
| Transfer word from RIP to RCS internal register | 000      | 00000      | 001         | ra  | ext2                                  | ×    | )                               |
| Transfer word from                              | 3        | 5          | 3           | 5   | 5                                     | 11   | } 46                            |
| Coprocessor to RCS internal                     | 000      | 00000      | 11          | ×   | ext2                                  | ×    | )                               |
| register                                        | 3        | 5          | 2           | 6   | 5                                     | 11   | ,                               |
| Transfer word from RCS internal register to RIP | 000      | 00000      | 011         | ra  | ext2                                  | 0    |                                 |
| Transfer word from RCS                          | 3        | 5          | 3           | 5   | 5                                     | 11   | } 48                            |
| internal register to                            | 000      | 00000      | 11          | X   | ext2                                  | ×    | }                               |
| Coprocessor                                     | 3        | 5          | 2           | 6   | 5                                     | 11   | •                               |
| Pop stack to RIP register                       | 000      | 00000      | 010         | ra  | 00000                                 | x    |                                 |
|                                                 | 3        | 5          | 3           | 5   | 5                                     | 11   | } 50                            |
| Pop stack to Coprocessor                        | 000      | 00000      | 101         | x   | 00000                                 | x    | ]                               |
|                                                 | 3        | 5          | 3           | 5   | 5                                     | 11   |                                 |
| Copy stack to RIP register                      | 000      | 00000      | 010         | ra  | 00001                                 | x    |                                 |
|                                                 | 3        | 5          | 3           | 5   | 5                                     | 11   | 51                              |
| Copy stack to Coprocessor                       | 000      | 00000      | 101         | x   | 00001                                 | x    |                                 |
|                                                 | 3        | 5          | 3           | 5   | 5                                     | 11   | ,                               |
| Push RIP register onto stack                    | 000      | 00000      | 000         | ra  | 00000                                 | x    | )                               |
|                                                 | 3        | 5          | 3           | 5   | 5                                     | 11   | 52                              |
| Push Coprocessor register<br>onto stack         | 000      | 00000      | 100         | x   | 00000                                 | x    |                                 |
| Shito Stack                                     | 3        | 5          | 3           | 5   | 5                                     | 11   | ,                               |
| Transfer word from RIP                          | 000      | 00000      | 001         | ra  | 1 extn                                | ×    |                                 |
| register to external register                   | 3        | 5          | 3           | 5   | 4                                     | 11   | 53                              |
| Transfer Coprocessor                            | 000      | 00000      | 11          | ×   | 1 extn                                | x    | $\int 33$                       |
| register to external register                   | 3        | 5          | 2           | 6   | 4                                     | 11   | J                               |
| Transfer word from                              | 000      | 00000      | 011         |     | 1 extn                                |      | ١                               |
| external register to RIP                        |          | 5          | 3           | ra5 | 1 extn 4                              | X    |                                 |
| Transfer external register                      |          |            | · · · · · · |     | · · · · · · · · · · · · · · · · · · · |      | > 54                            |
| to Coprocessor register                         | 000      | 00000      | 11          | ×   | 1 extn                                | X    |                                 |
|                                                 | 3        | 5          | 2           | 0   | 4                                     | 11   | )                               |
| Store Coprocessor                               | 101      | rd         |             |     | RP/coproces                           | sor  | )                               |
| Load RIP                                        | 110      | rd         |             | ſ   | RIP/coproces                          | SSOF |                                 |
| Load Coprocessor                                | 111      | rd         |             | F   | RIP/coproces                          | ssor | > 55                            |
| Store RIP                                       | 000<br>3 | 01001<br>5 |             | 1   | RIP/coproces<br>24                    | ssor | )                               |

## **Continue Instruction**

## CONTINUE



### FORMAT

cont

## DESCRIPTION

This instruction causes instruction fetching to proceed in normal, sequential fashion. The lower 24 bits are used for either an XL-8237 instruction or a coprocessor instruction. Short instruction format.

## NEUTRALIZATION

This instruction is neutralized if the b field of the .ssr contains a one.

| if b = 1 then   |
|-----------------|
| NEUT := true;   |
| b := 0;         |
| else            |
| NEUT := false;  |
| endif;          |
| cfa := cfa + 1; |
| AC := cfa;      |
|                 |

PRELIMINARY DATA October 1988

## **Branch Instructions Summary**

The following instructions are used for branching:



Figure 22. Format of branch instructions







Figure 24. Conditional branch timing-brc imm5 instruction.

## Branch Instructions, continued

## BRANCH



## FORMAT

br imm24

## DESCRIPTION

Causes the RCS to branch to the address specified by adding the sign-extended 24-bit immediate imm24 to the address of the currently executing instruction. Long instruction format.

## NEUTRALIZATION

This instruction is neutralized if the b bit of the .ssr contains a one. If the branch is taken, the b bit of the .ssr is set to one.

## EXCEPTIONS

None

PRELIMINARY DATA October 1988

## Branch Instructions, continued

SHORT BRANCH

 100
 imm5
 RiP/coprocessor

 3
 5
 24

### FORMAT

shbr imm5

### DESCRIPTION

Causes a branch to the address specified by adding the sign-extended 5-bit offset to the currently executing instruction. Short instruction format.

### NEUTRALIZATION

This instruction is neutralized if the b bit of the .ssr contains a one. If the branch is taken, the b bit of the .ssr is set to one.

### EXCEPTIONS

None

```
if b = 1 then
        NEUT := true;
        cfa := cfa + 1;
        b := 0;
else
        NEUT := false;
        cfa := cea + (28 dup imm[4]) || imm5[3..0];
        b := 1;
endif;
AC := cfa;
```

# **Branch Instructions, continued**

### BRANCH TO STACK AND POP

 000
 01110
 RIP/coprocessor

 3
 5
 24

### FORMAT

brstkp

### DESCRIPTION

This instruction takes a branch to the address specified by adding the value on the top of stack to the address of the currently executing instruction. The top of stack value is popped off. Short instruction format.

### NEUTRALIZATION

This instruction is neutralized if the b bit of the .ssr contains a one. The b bit of the .ssr is set to one.

### EXCEPTIONS

Stack underflow

PRELIMINARY DATA October 1988

## Branch Instructions, continued

SHORT FORWARD BRANCH ON CONDITION

 01
 c
 imm5
 RiP/coprocessor

 2
 1
 5
 24

FORMAT

brc imm5

### DESCRIPTION

If the selected condition is active, causes a branch to the address specified by adding the zero-extended 5-bit offset to the address of the currently executing instruction. If the 24-bit processor/coprocessor field contains a coprocessor instruction, then FPCN is tested; otherwise, COND is tested. See the *XL-8237 Data Sheet* for details of the processor/coprocessor instruction field. Short instruction format.

### NEUTRALIZATION

This instruction is neutralized if the b bit of the .ssr contains a one. If the branch is taken, the b bit of the .ssr is set to one.

### EXCEPTIONS

None

```
if b = 1 then
      NEUT := true;
      cfa := cfa + 1;
      b := 0;
else
      NEUT := false;
      if {processor operation is coprocessor} then
            cond := FPCN;
      else
            cond := COND;
      endif;
      if c \cdot cond then
            cfa := cfa + 1;
      else
            cfa := cea + (27 dup 0) || imm5[4..0];
            b := 1;
      endif;
endif:
AC := cfa;
```

## Loop Control Instructions Summary

The following instructions are used for loop control:

| loop                     | 000 00111                     | RIP/coprocessor |  |
|--------------------------|-------------------------------|-----------------|--|
|                          | 3 5                           | 24              |  |
|                          | or pop on condition (loopa a  | gain or exit)   |  |
| endloop                  | 000 01 c 00                   | RIP/coprocessor |  |
|                          | 3 2 1 2                       | 24              |  |
| Decrement stack and bac  | kward branch or pop if zero   | (for loopi end) |  |
| shsob imm5               | 001 imm5                      | RIP/coprocessor |  |
|                          | 3 5                           | 24              |  |
| Decrement stack and brar | nch or pop if zero (for loopi | end)            |  |
| Decrement stack and brai |                               |                 |  |
| sob imm24                | 000 00001                     | imm24           |  |
|                          | 000 00001<br>3 5              | imm24<br>24     |  |
| sob imm24                | 3 5                           |                 |  |
|                          | 3 5                           |                 |  |

Figure 25. Loop control instruction format

There are two kinds of loops: loops that run for a fixed number of iterations, using a loop count on the stack; and loops that run until a condition is met, with the top-of-loop branch address on the top of stack. The fixed-count loop is called a loopi; the conditional loop is called a loopa.



Figure 26. Loopa and Loopi

PRELIMINARY DATA October 1988

# Loop Control Instructions, continued

LOOP ENTER (PUSH FOLLOWING ADDRESS)

 000
 00111
 RIP/coprocessor

 3
 5
 24

### FORMAT

loop

### DESCRIPTION

This instruction pushes the address of the currently fetching instruction on the stack. Used to start loopa. Short instruction format.

### NEUTRALIZATION

This instruction is neutralized if the b bit of the .ssr contains a one.

### **EXCEPTIONS**

Stack overflow

## Loop Control Instructions, continued

## ABSOLUTE BRANCH TO STACK OR POP ON CONDITION (LOOP AGAIN OR EXIT)

 000
 01
 c
 00
 RiP/coprocessor

 3
 2
 1
 2
 24

## FORMAT

endloop

### DESCRIPTION

If the selected condition is asserted, causes a branch to the contents of the top of stack; otherwise, pops the stack and continues normal sequential execution. If the 24-bit processor/coprocessor field contains a coprocessor instruction, then FPCN is tested, otherwise COND is tested. See the *XL-8237 Data Sheet* for details of the processor/ coprocessor instruction field. Used to conditionally end a loopa. (See the brc instruction on page 27 for details of condition code selection.) Short instruction format.

### NEUTRALIZATION

This instruction is neutralized if the b bit of the .ssr contains a one. If the branch is taken, the b bit of the .ssr is set to one.

## **EXCEPTIONS**

Stack underflow

```
if b = 1 then
      NEUT := true:
      cfa := cfa + 1;
      b := 0;
else
      NEUT := false:
      if {processor operation is coprocessor} then
            cond := FPCN;
      else
            cond := COND;
      endif;
      if c · cond then
            cfa := cfa + 1;
            tos := tos - 1;
             b := 0;
      else
             cfa := stack(tos);
             b := 1;
      endif;
endif;
AC := cfa;
```

## PRELIMINARY DATA October 1988

## Loop Control Instructions, continued

DECREMENT STACK AND BRANCH OR POP IF ZERO (FOR LOOPI END)

| 000 | 00001 | imm24 |
|-----|-------|-------|
| 3   | 5     | 24    |

### FORMAT

sob imm24

### DESCRIPTION

The acronym sob stands for subtract-one-and-branch. This instruction subtracts one from the top of stack, replacing result back on the top-of-stack. If the result is non-zero, a branch is caused to the address specified by adding the sign-extended 24-bit immediate imm24 to the address of the currently executing instruction. If the result is zero, the value on the top-of-stack is popped off and discarded, and the normal sequential execution resumes. Useful at bottoms of loops designed to continue a set number of iterations (loopi). Long instruction format.

Note that the initial count must be non-negative, (that is, the high bit must be zero) for the instruction to work properly.

### NEUTRALIZATION

This instruction is neutralized if the b bit of the .ssr contains a one. If the branch is taken, the b bit of the .ssr is set to one.

### **EXCEPTIONS**

Stack underflow

### **OPERATION**

```
if b = 1 then
      NEUT := true;
      cfa := cfa + 1;
      b := 0;
else
      NEUT := false;
      stack(tos) := stack(tos) - 1;
      if stack(tos) = 0 then
            cfa := cfa + 1;
            tos := tos -1;
      else
            cfa := cea + (9 dup imm24[23]) || imm24[22..0];
             b := 1;
      endif;
endif;
AC := cfa;
```

© Copyright WEITEK 1988 All rights reserved

## Loop Control Instructions, continued

## DECREMENT STACK AND BACKWARD BRANCH OR POP IF ZERO (FOR LOOPI END)

 001
 imm5
 RIP/coprocessor

 3
 5
 24

FORMAT

shsob imm5

### DESCRIPTION

Same instruction as sob, but performs the branch based on the one-extended field imm5 instead of the 24-bit immediate that sob uses. Used to end a loopi. Short instruction format.

Note that the initial count must be non-negative for the instruction to work properly.

### NEUTRALIZATION

This instruction is neutralized if the b bit of the .ssr contains a one. If the branch is taken, the b bit of the .ssr is set to one.

## EXCEPTIONS

Stack underflow

### **OPERATION**

```
if b = 1 then
      NEUT := true;
      cfa := cfa + 1;
      b := 0;
else
      NEUT := false;
      stack(tos) := stack(tos) - 1;
      if stack(tos) = 0 then
            cfa := cfa + 1;
            tos := tos - 1;
            b := 0;
      else
            cfa := cea + (27 dup 1) || imm5[4..0];
            b := 1;
      endif;
endif;
AC := cfa;
```

© Copyright WEITEK 1988 All rights reserved

PRELIMINARY DATA October 1988

## Loop Control Instructions, continued

BRANCH AND POP (LOOPI/LOOPA EXIT)

 000
 00011
 imm24

 3
 5
 24

FORMAT

brp imm24

### DESCRIPTION

Branches to the address specified by adding the sign-extended 24-bit immediate imm24 to the address of the currently executing instruction. The value on the top of stack is popped off and discarded. Used to unconditionally or prematurely exit a loopa or loopi. Long instruction format.

### NEUTRALIZATION

This instruction is neutralized if the b bit of the .ssr contains a one. If the branch is taken, the b bit of the .ssr is set to one.

### EXCEPTIONS

Stack underflow

# **Subroutine Control Instructions Summary**

The following instructions are used for subroutine control:







Figure 28. Subroutine call and return

PRELIMINARY DATA October 1988

#### Subroutine Control Instructions, continued

SUBROUTINE CALL

0001 imm28 4 28

FORMAT

bsr imm28

#### DESCRIPTION

Pushes the address of the currently fetching instruction on the stack and branches to the address specified by the sum of the sign-extended 28-bit immediate imm28 and .cea. Long instruction format.

#### NEUTRALIZATION

This instruction is neutralized if the b bit of the .ssr contains a one. The b bit of the .ssr is set to one.

#### EXCEPTIONS

Stack overflow

```
if b = 1 then
            NEUT := true;
            cfa := cfa + 1;
            b := 0;
else
            NEUT := false;
            tos := tos + 1;
            stack(tos) := cfa;
            cfa := cea + (5 dup imm28[27]) || imm28[26..0];
            b := 1;
endif;
AC := cfa;
```

#### Subroutine Control Instructions, continued

#### SUBROUTINE RETURN

 000
 01101
 RiP/coprocessor

 3
 5
 24

#### FORMAT

rts

#### DESCRIPTION

The value on the top of the stack is used as an absolute branch address and discarded. Short instruction format.

#### NEUTRALIZATION

This instruction is neutralized if the b bit of the .ssr contains a one. The b bit of the .ssr is set to one.

#### EXCEPTIONS

Stack underflow

#### PRELIMINARY DATA October 1988

# **Interrupt Control Instructions Summary**

The following instructions are used to return from interrupt:



Figure 29. Interrupt control instructions

The following instructions are used to cause software interrupts (traps):





# **Interrupt Control Instructions, continued**

#### **RETURN FROM INTERRUPT (rfi0)**



#### FORMAT

rfi0

#### DESCRIPTION

First of a two-step instruction sequence to restore the RCS state after an interrupt. Restores .cfa from .iea, and enables interrupts by setting the men bit. The rfi0 instruction must be followed by the rfi1 instruction. Long instruction format.

The effect of setting men bit may not take place until one cycle after the rfi0 instruction.

All internal exceptions should be processed before the interrupt handler is exited.

#### NEUTRALIZATION

This instruction is neutralized if the b bit of the .ssr is a one.

#### EXCEPTIONS

None

#### PRELIMINARY DATA October 1988

### Interrupt Control Instructions, continued

#### **RETURN FROM INTERRUPT (rfi1)**

 000
 00100
 RIP/coprocessor

 3
 5
 24

#### FORMAT

rfi1

#### DESCRIPTION

Second of a two-step instruction sequence to restore the RCS state after an interrupt. Short instruction format. Rfi1 stores the contents of the .ifa to the .cfa and places the contents of the .ifa onto the AC bus. The .ssr bi bit is stored into .ssr b to indicate if the last instruction of the interrupted process was a branch. The rfi1 instruction must always be preceded by the rfi0 instruction. Short instruction format.

#### NEUTRALIZATION

This instruction is neutralized if the b bit of the .ssr contains a one.

#### **EXCEPTIONS**

None

```
if b = 1 then
      cfa := cfa + 1;
      b := 0:
      NEUT := FALSE;
else
      NEUT := FALSE:
      if ssr.s = 1 then
             cfa := ifa;
             ssr.b := ssr.bi;
             ssr.s := ssr.si;
             OP := 00111;
      else
             ssr.prvflg := TRUE;
      endif;
endif:
AC := cfa;
```

# **Trap Instructions**

#### TRAP IMMEDIATE



#### FORMAT

trapi imm11

#### DESCRIPTION

This instruction sets the trpflg bit of the .ssr. If enabled, the RCS causes an interrupt and pushes an 11-bit zero-extended immediate value onto the stack. The trap flag (trpflg) in .ssr is set when a trap occurs.

#### NEUTRALIZATION

This instruction is neutralized if the b bit of the ssr contains a one.

#### **EXCEPTIONS**

Stack overflow and trap

```
if b = 0 then
    ssr.trpflg := 1;
    if (ssr.men = 1) and (ssr.trpen = 1) then
        stack(tos) := 21 dup 0 || imm11[10..0];
        tos := tos + 1;
    endif;
endif;
b := 0;
cfa := cfa + 1;
```

PRELIMINARY DATA October 1988

#### **Neutralization Instructions Summary**

The RCS has three short-format instructions that change the neutralization of shadow instructions after branching, subroutine calls and returns.



Figure 31. Neutralization instruction format



Figure 32. Conditional branch timing with override and reverse neutralization

# Neutralization Instructions, continued



Figure 33. Conditional branch timing with override neutralization

.

PRELIMINARY DATA October 1988

#### Neutralization Instructions, continued

#### OVERRIDE NEUTRALIZATION OF BRANCH SHADOW

 000
 01011
 RIP/coprocessor

 3
 5
 24

#### FORMAT

ovneut

#### DESCRIPTION

Causes the neutralization effect—which normally cancels the execution of an instruction immediately following a branch (or other transfer-of-control operation)—to be overridden. The instruction is unconditionally executed (unless neutralized due to an interrupt). This instruction has a short format and is placed with the shadow instruction to be executed, immediately following the branch.

#### NEUTRALIZATION

This instruction is executed regardless of the value of the b field of the .ssr.

EXCEPTIONS

None

#### OPERATION

NEUT := false; cfa := cfa + 1; b := 0; AC := cfa;

#### Neutralization Instructions, continued

#### OVERRIDE NEUTRALIZATION OF SUBROUTINE CALL SHADOW

 000
 01111
 RIP/coprocessor

 3
 5
 24

#### FORMAT

ovneuti

#### DESCRIPTION

This instruction is the same as ovneut, but after executing the shadow instruction, the stack is incremented. Thus a subroutine return is made *not* to the shadow instruction but to the one following it. This instruction has a short format and is placed with the shadow processor operation to be executed, immediately following the subroutine call.

#### NEUTRALIZATION

This instruction is executed regardless of the b bit of the .ssr.

#### **EXCEPTIONS**

None

```
NEUT := false;
stack(tos) := stack(tos) + 1;
cfa := cfa + 1;
b := 0;
AC := cfa;
```

#### PRELIMINARY DATA October 1988

#### Neutralization Instructions, continued

#### REVERSE NEUTRALIZATION OF BRANCH SHADOW

 000
 00101
 RIP/coprocessor

 3
 5
 24

#### FORMAT

revneut

#### DESCRIPTION

Reverses the neutralization effect that would normally have been applied to an instruction. If it would normally have been neutralized, it is not; if it would normally *not* have been neutralized, it is. Short instruction format.

This instruction is typically used to allow the shadow instruction to be executed as part of a loop, rather than being neutralized. This saves one cycle per iteration.

#### **EXCEPTIONS**

None

#### NEUTRALIZATION

This instruction is neutralized if the b bit of the .ssr contains a zero.

**OPERATION** 

#### 

# Intrasystem Data Transfer Instructions

#### TRANSFER WORD TO RCS INTERNAL REGISTER

| ſ | 000 | 00000 | 001 | ra | ext2 | x  | from RIP         |
|---|-----|-------|-----|----|------|----|------------------|
|   | 3   | 5     | 3   | 5  | 5    | 11 | -                |
| Γ | 000 | 00000 | 11  | x  | ext2 | x  | from coprocessor |
|   | 3   | 5     | 2   | 6  | 5    | 11 |                  |

#### FORMAT

From RIP

| mov | ra, .tim | $\{ext2 = 00110b\}$ |
|-----|----------|---------------------|
| mov | ra, .ssr | $\{ext2 = 01000b\}$ |
| mov | ra, .iea | {ext2 = 01010b}     |
| mov | ra, .ifa | {ext2 = 01100b}     |
| mov | ra, .brk | {ext2 = 01110b}     |
| mov | ra, .ibr | {ext2 = 01111b}     |

From Coprocessor

| mov | .adbus, .tim | {ext2 = 00110b}     |
|-----|--------------|---------------------|
| mov | .adbus, .ssr | $\{ext2 = 01000b\}$ |
| mov | .adbus, .iea | {ext2 = 01010b}     |
| mov | .adbus, .ifa | {ext2 = 01100b}     |
| mov | .adbus, .brk | $\{ext2 = 01110b\}$ |
| mov | .adbus, .ibr | $\{ext2 = 01111b\}$ |
|     |              |                     |

#### DESCRIPTION

These instructions cause the RCS to write the contents of the AD bus into the selected internal register. The two instruction formats differ in their effect on the other components in the system. The first set is recognized by the RIP and causes it to drive the AD bus with one register from its register file. The second set allows a coprocessor to drive the AD bus. Long instruction format.

#### NEUTRALIZATION

These instructions are not neutralized reliably, and therefore must not be put into branch shadows. Furthermore, since interrupts cause an instruction to be neutralized, these instructions must only be used when interrupts are disabled.

PRELIMINARY DATA October 1988

# Intrasystem Data Transfer Instructions, continued

```
{ Note: the cancellation of the instruction by NEUT- does not always work. }
if b = 1 then
      NEUT := TRUE;
else
      NEUT := FALSE;
      if ssr.s = 0 then
            ssr.prvflg := TRUE;
      else
            case ext2 {AD bus is driven by the RIP or a coprocessor} of
                  00110b :
                                     := AD;
                              tim
                  01000b :
                                     := AD;
                              ssr
                  01110b :
                                     := AD;
                              ibr
                  01010b :
                                    { no action }
                              ;
                  01100b :
                                    { no action }
                              ;
                  01110b :
                                    { no action }
                              ;
            endcase;
      endif;
else
      case ext2 of
            00110b : tim
                               := AD;
            01000b : ssr
                               := AD;
            01110b : ibr
                               := AD;
            01010b : iea
                               := AD;
            01100b : ifa
                               := AD;
            01110b : brk
                               := AD;
      endcase:
endif;
b := 0;
cfa := cfa + 1;
AC := cfa;
```

# Intrasystem Data Transfer Instructions, continued

TRANSFER WORD FROM RCS INTERNAL REGISTER

| 000                                                          | 00000                 | 011 | ra | ext2 | 0  | to RIP                                                 |  |  |  |  |
|--------------------------------------------------------------|-----------------------|-----|----|------|----|--------------------------------------------------------|--|--|--|--|
| 3                                                            | 5                     | 3   | 5  | 5    | 11 | 1                                                      |  |  |  |  |
| 000                                                          | 00000                 | 11  | x  | ext2 | x  | to coprocessor                                         |  |  |  |  |
| 3                                                            | 5                     | 2   | 6  | 5    | 11 |                                                        |  |  |  |  |
| FORM                                                         | FORMAT                |     |    |      |    |                                                        |  |  |  |  |
| To RIP                                                       | To RIP To Coprocessor |     |    |      |    |                                                        |  |  |  |  |
| mov .tim, ra {ext2 = 00111b}<br>mov .ssr, ra {ext2 = 01001b} |                       |     |    |      |    | n, .adbus {ext2 = 00111b}<br>r, .adbus {ext2 = 01001b} |  |  |  |  |

#### DESCRIPTION

The RCS drives the AD bus with the contents of the designated register. The different formats allow either the RIP or the coprocessor to receive the data. Long instruction format.

mov

mov

.iea, .adbus

.ifa, .adbus

#### NEUTRALIZATION

.iea, ra

.ifa, ra

These instructions are neutralized if the b bit of the .ssr is a one.

 $\{ext2 = 01011b\}$ 

 $\{ext2 = 01101b\}$ 

EXCEPTIONS

None

mov

mov

 $\{ext2 = 01011b\}$ 

 $\{ext2 = 01101b\}$ 

PRELIMINARY DATA October 1988

# Intrasystem Data Transfer Instructions, continued

**OPERATION** 

 $\mathbf{C}$ 

```
if b = 1 then
     NEUT := TRUE;
else
     NEUT := FALSE;
     if ssr.s = 0 then
           ssr.prvflg := TRUE;
     endif;
     case ext2 of
           00111b : AD
                            := tim;
           01001b : AD := ssr;
           01011b : AD := iea;
           01101b : AD
                            := ifa;
     endcase;
endif;
b := 0;
cfa := cfa + 1;
```

# Intrasystem Data Transfer Instructions, continued

#### POP STACK TO RIP REGISTER OR COPROCESSOR

| 000 | 00000 | 010 | ra | 00000 | x  | Pop to RIP         |
|-----|-------|-----|----|-------|----|--------------------|
| 3   | 5     | 3   | 5  | 5     | 11 |                    |
| 000 | 00000 | 101 | x  | 00000 | x  | Pop to coprocessor |
| 3   | 5     | 3   | 5  | 5     | 11 |                    |

#### FORMAT

| pops | ra     | {pop to RIP}         |
|------|--------|----------------------|
| or   |        |                      |
| pops | .adbus | {pop to coprocessor} |

#### DESCRIPTION

The contents of the top of the stack are driven onto the AD bus. The stack is popped. The RIP recognizes the first format and latches the data from the AD bus. Long instruction format.

#### NEUTRALIZATION

These instructions are neutralized if the b bit of the .ssr is a one.

#### **EXCEPTIONS**

Stack underflow

```
if b = 1 then
    NEUT := TRUE;
else
    NEUT := FALSE;
    AD := stack (tos);
    tos := tos - 1;
endif;
b := 0;
cfa := cfa + 1;
AC := cfa;
```

PRELIMINARY DATA October 1988

# Intrasystem Data Transfer Instructions, continued

COPY STACK TO RIP REGISTER OR COPROCESSOR

| 000 | 00000 | 010 | ra | 00001 | ×  | Copy stack to RIP register |
|-----|-------|-----|----|-------|----|----------------------------|
| 3   | 5     | 3   | 5  | 5     | 11 | -                          |
| 000 | 00000 | 101 | x  | 00001 | x  | Copy stack to Coprocessor  |
| 3   | 5     | 3   | 5  | 5     | 11 |                            |

#### FORMAT

| mov | .tos, ra     | {copy to RIP}         |
|-----|--------------|-----------------------|
| mov | .tos, .adbus | {copy to coprocessor} |

#### DESCRIPTION

The contents of the top of the stack are driven onto the AD bus. The stack is *not* popped. The RIP recognizes the first format and latches the data from the AD bus. Long instruction format.

#### NEUTRALIZATION

These instructions are neutralized if the b bit of the .ssr is a one.

**EXCEPTIONS** 

None

#### OPERATION

© Copyright WEITEK 1988

### Intrasystem Data Transfer Instructions, continued

# PUSH RIP REGISTER OR COPROCESSOR ONTO STACK

| 000 | 00000 | 000 | ra | 00000 | x  | Push RIP register |
|-----|-------|-----|----|-------|----|-------------------|
| 3   | 5     | 3   | 5  | 5     | 11 |                   |
| 000 | 00000 | 100 | x  | 00000 | x  | Push Coprocessor  |
| 3   | 5     | 3   | 5  | 5     | 11 | -                 |

#### FORMAT

| pushs | ra     | {push RIP register} |
|-------|--------|---------------------|
| pushs | .adbus | {push coprocessor}  |

#### DESCRIPTION

The contents of the AD Bus are pushed onto the RCS stack. The RIP recognizes the first format and drives the AD bus with the selected register. Long instruction format.

#### NEUTRALIZATION

These instructions are neutralized if the b bit of the .ssr is a one.

#### **EXCEPTIONS**

Stack overflow

PRELIMINARY DATA October 1988

#### Intrasystem Data Transfer Instructions, continued

TRANSFER WORD TO EXTERNAL REGISTER



#### FORMAT

mov ra, extn mov .adbus, extn

#### DESCRIPTION

For all formats the OP bus is driven by the external register number (must be in the range 0000b-1110b). Long instruction format. Other than driving the OP bus, the RCS treats the RIP and coprocessor forms of this instruction as a no-op.

Note: the transfer to and transfer from coprocessor to/from external register instructions have the same format. The actual direction of the transfer is a convention between the coprocessor and the external register and is not specified here.

#### NEUTRALIZATION

These instructions are neutralized if the b bit of the .ssr is a one.

**EXCEPTIONS** 

Stack underflow

# Intrasystem Data Transfer Instructions, continued

#### TRANSFER WORD FROM EXTERNAL REGISTER

| 000 | 00000 | 011         | ra | 1 | extn | x  | External register to RIP         |
|-----|-------|-------------|----|---|------|----|----------------------------------|
| 3   | 5     | 3           | 5  | 1 | 4    | 11 | _                                |
|     |       | <del></del> |    |   |      |    | -                                |
| 000 | 00000 | 11          | x  | 1 | extn | X  | External register to Coprocessor |
| 3   | 5     | 2           | 6  | 1 | 4    | 11 | -                                |

#### FORMAT

mov extn, ra mov extn, .adbus

#### DESCRIPTION

Takes a word from the AD bus and copies it to a register in the RIP or coprocessor.

For all formats the OP bus is driven by the external register number (must be in the range 0000b-1110b). Other than driving the OP bus, the RCS treats the RIP and coprocessor forms of this instruction as a no-op. Long instruction format.

Note: the transfer to and transfer from coprocessor to/from external register instructions have the same format. The actual direction of the transfer is a convention between the coprocessor and the external register and is not specified here.

#### NEUTRALIZATION

These instructions are neutralized if the b bit of the .ssr is a one.

#### **EXCEPTIONS**

Stack overflow

#### PRELIMINARY DATA October 1988



fload frd (or dload dfrd, dloadm dfrd, dloadl dfrd)

#### DESCRIPTION

The RIP or coprocessor performs a load or store over the D bus (which is not connected to the RCS). The RCS merely drives the OP bus to indicate RIP load, coprocessor load, RIP store, or coprocessor store. Otherwise, it treats load and store cycles as no-ops. Note that no register is specified for the RIP Store operation; the result of the accompanying RIP operation is simultaneously stored in an RIP register and in the previously addressed word of memory.

#### NEUTRALIZATION

This instruction is neutralized if the b bit of the .ssr contains a one.

#### **EXCEPTIONS**

None

# Intrasystem Data Transfer Instructions, continued

#### **OPERATION**

```
if b = 1 then
      NEUT := true;
      b := 0;
else
      NEUT := false;
      if {Store RIP} then
            OP := 01000b or 01001b;*
      endif;
      if {Store Coprocessor} then
            OP := 01100b or 01101b;*
      endif;
      if {Load RIP} then
            OP := 01010b or 01011b;*
      endif:
      if {Load Coprocessor} then
            OP := 01110b or 01111b;*
      endif;
endif:
cfa := cfa + 1;
AC := cfa;
```

\* The selection between even or odd OP Bus value is based on the 24-bit RIP operation. If the operation specifies data address generation then the odd value is used, otherwise the even value is used. See *XL-8237 Data Sheet* for address generation instructions.

# **PRELIMINARY DATA** October 1988

# **Instruction Interaction**

C

 $\bigcirc$ 

|                        | <u></u>                                                           |                     |                            |                                                                                                                                                                                                |                                 |
|------------------------|-------------------------------------------------------------------|---------------------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
|                        | cfa                                                               | сеа                 | EXECL                      | JTING INSTRUCTION                                                                                                                                                                              | COMMENT                         |
|                        | N + 1<br>N + P<br>N+P+1                                           | N<br>N + 1<br>N + P | br N + P<br>〈 〉<br>〈 〉     | <pre></pre>                                                                                                                                                                                    | branch taken<br>neutralized     |
| taken<br>branch        | N + 1<br>N + P<br>N+P+1                                           | N<br>N + 1<br>N + P | br N + P<br>revneut<br>〈 〉 | <pre></pre>                                                                                                                                                                                    | branch taken<br>executed        |
|                        | N + 1<br>N + P<br>N+P÷1                                           | N<br>N + 1<br>N + P | br N + P<br>ovneut<br>〈 〉  | <pre></pre>                                                                                                                                                                                    | branch taken<br>executed        |
|                        | N + 1<br>N + 2<br>N + 3                                           | N<br>N + 1<br>N + 2 | br N + P<br>〈 〉<br>〈 〉     | <pre></pre>                                                                                                                                                                                    | branch not taken<br>executed    |
| not<br>taken<br>branch | N + 1<br>N + 2<br>N + 3                                           | N<br>N + 1<br>N + 2 | br N + P<br>revneut<br>〈 〉 | <pre></pre>                                                                                                                                                                                    | branch not taken<br>neutralized |
| V                      | N + 1<br>N + 2<br>N + 3                                           | N<br>N + 1<br>N + 2 | br N + P<br>ovneut<br>〈 〉  | <pre></pre>                                                                                                                                                                                    | branch not taken<br>executed    |
|                        | Branch i                                                          | instruction         | IS                         | Comment                                                                                                                                                                                        |                                 |
|                        | br imm2<br>brp<br>shbr imr<br>brc imm<br>rts<br>ovneut<br>revneut | m5                  |                            | unconditional .cea relative<br>unconditional absolute<br>unconditional .cea relative<br>conditional .cea relative<br>unconditional absolute<br>branch shadow override<br>branch shadow reverse |                                 |

Figure 34. Effects of branching on code execution

Instruction Interaction, continued

|           | cfa      | cea        | EXE          | CL | JTING INSTRUCTION       | COMMENT                         | STAC  |
|-----------|----------|------------|--------------|----|-------------------------|---------------------------------|-------|
|           | N + 1    | N          | bsr N + F    | <  | RIP/coprocessor )       | call                            | -     |
|           | N + P    | N + 1      | < >          | <  | RIP/coprocessor >       | neutralized                     | N + 1 |
|           | N+P+1    | N + P      | < >          | <  | RIP/coprocessor >       | top of subroutine               | N + 1 |
| l<br>call |          |            | •            |    |                         |                                 |       |
| 1         | N+Q+1    | N + Q      | rts          | <  | RIP/coprocessor >       | return – bottom                 | N + 1 |
|           | N + 1    | N+Q+1      | < >          | <  | >                       | neutralized                     | -     |
|           | N + 2    | N + 1      | < >          | <  | RIP/coprocessor         |                                 |       |
|           | N + 3    | N + 2      | ( )          | <  | RIP/coprocessor         |                                 |       |
| <b>_</b>  |          |            |              |    |                         |                                 |       |
| 1         |          |            |              | ,  |                         |                                 |       |
|           | N + 1    | N          | bsr N + F    | Ś  | RIP/coprocessor >       | call                            |       |
|           | N + P    | N + 1      | ovneuti      | Ś  | RIP/coprocessor >       | executed – top of<br>subroutine | N + 1 |
| all with  | N+P+1    | N + P      | < <u>`</u> > | <  | RIP/coprocessor >       |                                 | N + 2 |
| verride   |          |            | •            |    |                         |                                 |       |
|           | N+Q+1    | N + Q      | rts          | <  | RIP/coprocessor >       | return                          | N + 2 |
|           | N + 2    | N+Q+1      | ovneut       | <  | RIP/coprocessor >       | executed - bottom of            | -     |
|           | N + 3    | N + 2      | < >          | <  | RIP/coprocessor >       | subroutine                      | -     |
|           | N + 4    | N + 3      | < >          | <  | RIP/coprocessor >       |                                 | -     |
|           |          |            |              |    |                         |                                 | l     |
|           | Subrouti | ne call in | structions   |    | Comment                 |                                 |       |
|           | bsr imm  | 28         |              |    | unconditional cea rela  | itive                           |       |
|           | ovneuti  |            |              |    | override neutralizatior | n and increment stack           |       |



**PRELIMINARY DATA** October 1988

# Instruction Interaction, continued

 $\bigcirc$ 

|         | cfa          | сеа        | EXE                | ECU      | TING INSTRUCTION             | <br>COMMENT                  | STACK |
|---------|--------------|------------|--------------------|----------|------------------------------|------------------------------|-------|
|         | N + 1        | N          | loop               | <        | RIP/coprocessor >            | -                            | -     |
|         | N + 2        | N + 1      | ( )                | -        | RIP/coprocessor >            | top of loopa                 | N + 1 |
|         | N + 3        | N + 2      | < <u>`</u> >       | <        | RIP/coprocessor >            |                              | N + 1 |
|         | .            |            | •                  |          |                              | •                            |       |
|         | N+Q+1        | N + Q      | endloop            | <        | RIP/coprocessor >            | bottom of loopa (not<br>end) | N + 1 |
| loopa   | N + 1        | N+Q+1      | ( )                | <        | RIP/coprocessor >            | neutralized                  | N + 1 |
|         | N + 2        | N + 1      | ( )                | <        | RIP/coprocessor >            | top of loopa                 | N + 1 |
|         | N + 3        | N + 2      | < >                | <        | RIP/coprocessor >            | -                            | N + 1 |
|         |              |            | •                  |          |                              | •                            |       |
|         | N+Q+1        | N + Q      | endloop            | (        | RIP/coprocessor >            | bottom of loopa (end)        | N + 1 |
|         | N+Q+2        | N+Q+1      | $\langle \rangle$  | •        | RIP/coprocessor >            | execute                      | _     |
|         | N+Q+3        | N+Q+2      | $\langle \rangle$  | Ì        | RIP/coprocessor >            | _                            |       |
|         | N – P        | N-P-1      | pushs ra           | <u> </u> |                              | <br>load stack with count    | _     |
|         | N-P+1        | N – P      | $\langle \rangle$  | (        | RIP/coprocessor >            | top of loop;                 | 2     |
|         | N-P+2        | N-P+1      | $\langle \rangle$  | -        | RIP/coprocessor >            | -                            | 2     |
|         | •            |            |                    | `        | /                            | •                            |       |
|         | Ň            | N – 1      | $\langle  \rangle$ | ,        |                              | •                            | 2     |
|         | N + 1        | N = 1<br>N | sob                | (        | RIP/coprocessor >            | bottom of loopi              | 2     |
| l loopi | N – P        | N + 1      |                    | ,        |                              | neutralize                   | 1     |
|         | N-P+1        | N – P      | $\langle \rangle$  |          | RIP/coprocessor >            | neutralize                   | 1     |
|         | N-P+2        | N-P+1      |                    | -        | RIP/coprocessor >            |                              |       |
|         | •            | ·          | < <u>`</u> >       | \        | nir/coprocessor y            |                              |       |
|         |              |            | •                  |          |                              | •                            |       |
|         | N            | N – 1      | ( )                | <        | RIP/coprocessor >            | _                            | 1     |
|         | N + 1        | N          | sob                |          |                              | bottom of loopi - end        | 1     |
|         | N + 2        | N + 1      | ( )                | <        | RIP/coprocessor >            | execute                      | 0     |
|         | N + 3        | N + 2      | ( )                | <        | RIP/coprocessor >            | -                            | 0     |
|         | N + 4        | N + 3      | ( )                | <        | RIP/coprocessor >            | _                            |       |
|         |              |            |                    |          |                              |                              |       |
| (       | _oop inst    | ructions   |                    |          | Comment                      |                              |       |
|         | оор          |            |                    |          | loopa top                    |                              |       |
|         | endloop      |            |                    |          | loopa bottom                 |                              |       |
|         | shsob<br>sob |            |                    |          | loopi bottom<br>loopi bottom |                              |       |
| 1       | orp          |            |                    |          | loopa/loopi exit             |                              |       |
|         |              |            |                    |          |                              |                              |       |

Figure 36. Effects of looping instructions. Loopa uses the stack for the loop address and loopi uses the stack for the loop count.

I

|           | cfa    | cea   | EXECUTING INSTRUCTION                                     | COMMENT            | IFA   | IEA              | MASTER<br>INTERRUP<br>ENABLE |
|-----------|--------|-------|-----------------------------------------------------------|--------------------|-------|------------------|------------------------------|
|           | N – 1  | N – 2 | ⟨seq⟩, ⟨ RIP/coprocessor ⟩                                | application        | _     | -                | 1                            |
|           | N      | N – 1 | ⟨seq⟩, ⟨RIP/coprocessor⟩                                  |                    | -     | -                | 1                            |
|           | N + 1  | N     | ⟨seq⟩, ⟨RIP/coprocessor⟩                                  | interrupt          | -     | -                | 1                            |
|           | 1      | N + 1 | $\langle seq \rangle$ , $\langle RIP/coprocessor \rangle$ | neutralized        | N + 2 | N + 1            | 0                            |
|           | 1+1    | T     | ⟨seq⟩, ⟨RIP/coprocessor⟩                                  | interrupt routine  | N + 2 | N + 1            | 0                            |
| interrupt | l + 2  | 1+1   | ⟨seq⟩, ⟨RIP/coprocessor⟩                                  |                    | N + 2 | N + 1            | 0                            |
|           |        |       |                                                           | •                  |       |                  | •                            |
|           | ·<br>J | J – 1 | rfi0                                                      | •                  | N + 2 | N <del>i</del> 1 | 0                            |
|           | N + 1  | J     | rfi1 , asrtadr                                            | restart load/store | N + 2 | N + 1            | 0 or 1                       |
|           | N + 2  | N + 1 | <pre>{seq}, &lt; RIP/coprocessor &gt;</pre>               | application        | -     | -                | 1                            |
|           | N + 3  | N + 2 | <pre>{seq&gt;, &lt; RIP/coprocessor &gt;</pre>            | application        | -     | -                | 1                            |

Figure 37. Interrupt sequence, showing the transition from the application program to the interrupt handler and back.

#### PRELIMINARY DATA October 1988

### **OP** Output Bus Operation

The OP bus is provided to indicate to external logic the current operation of the system. Its primary use is to indicate the status of the D and AD buses. On each cycle, the RCS examines the state of the system and the current instruction (the entire 32-bit instruction is examined even if the current RCS instruction has short format) and selects the appropriate OP bus code. Figure 38 lists OP bus codes.

#### DEFAULT

The default code indicates that nothing interesting is happening during this cycle. This code is asserted whenever none of the others is asserted. This code is also asserted during any cycle where STALL- was asserted at the end of the previous cycle

#### DATA ADDRESS

These codes indicate that the RIP is currently executing an address generation instruction, that is, any cycle in which the AD bus will be driven with a data address.

#### LOAD RIP DATA

The RIP is executing a load data instruction. The D bus should be driven by the memory subsystem with the correct data. This code can also occur if the RIP executes an align (byte align for load data) instruction, even though this instruction loads no data. Memorymapped peripherals can be fooled by this false indication. For this reason we recommend that external register I/O be used instead of memory-mapped I/O.

#### LOAD COPROCESSOR DATA

The coprocessor is executing a load data instruction. The D bus should be driven by the memory subsystem with the correct data. Most systems treat these codes the same as the load processor data codes.

| OP+   | DESCRIPTION OF CURRENT INSTRUCTION  |
|-------|-------------------------------------|
| 00000 | default                             |
| 00001 | data address*                       |
| 00010 | interrupt acknowledge, or reset     |
| 00011 | reserved                            |
| 00100 | return from interrupt 0             |
| 00101 | reserved                            |
| 00110 | reserved                            |
| 00111 | return from interrupt 1*            |
| 01000 | store RIP data                      |
| 01001 | store RIP data and data address*    |
| 01010 | load RIP data†                      |
| 01011 | load RIP data and data address* †   |
| 01100 | store coprocessor                   |
| 01101 | store coprocessor and data address* |
| 01110 | load coprocessor                    |
| 01111 | load coprocessor and data address*  |
| 10000 | select external register #0         |
| :     | :                                   |
| 11101 | select external register #13        |
| 11110 | select external register #14        |
| 11111 | reserved                            |

The external data address register should be clocked on these combinations only. These codes can also be generated by the byte align for load instruction (align) in the RIP, even though this instruction loads no data. For this reason, memory-mapped peripherals should be used with caution or not at all.

Figure 38. OP bus decoding

#### **OP** Output Bus Operation, continued

#### STORE RIP DATA

The RIP is executing a store data instruction. For details of the timing of the D bus and WREN- bus outputs relative to the store data instruction, refer to the XL-8237 Data Sheet.

#### STORE COPROCESSOR DATA

The coprocessor is executing a store coprocessor data instruction. For timing details refer to the XL-8237 and XL-3132 Data Sheets.

#### INTERRUPT ACKNOWLEDGE

The RCS is currently honoring an interrupt request. This code appears during the cycle in which the AC bus address reflects the first instruction of the interrupt routine. The instruction that would normally have been executed during this cycle is always neutralized.

#### **RETURN FROM INTERRUPT 0**

The current instruction is rfi0.

#### **RETURN FROM INTERRUPT 1**

The current instruction is rfi1. If the RIP is executing an address generation instruction, then this instruction will also drive out the internal .adr register onto the AD Bus to allow the external address register to be updated to reflect its contents before the interrupt is serviced. Thus, this code is also used to clock the external .adr register. To accomplish this, the first eight most significant bits of the instruction specify the RCS rfi1 instruction, and the other 24 bits specify an RIP asrtadr instruction. See the *XL-8237 Data Sheet* for more details.

#### SELECT EXTERNAL REGISTER

The current instruction is a move to/from external register instruction. The AD bus in this cycle will be used for this intra-processor transfer.

#### **Development Tools**

WEITEK provides a family of software tools to aid applications development and debugging, using the XL-8236 and its companion processors, the XL-8237 32-bit raster image processor and the XL-3232 32-bit graphics floating point data path unit.

The XL-8236 is part of WEITEK's XL-Series of processor, and is largely compatible with them. All devices in WEITEK's XL-Series use the same development tools.

#### HIGH-LEVEL LANGUAGE COMPILERS

The XL-Series supports industry-standard implementations of C and FORTRAN 77 compilers. Industry-standard implementations allow existing programs to be ported to the XL-Series without modification. These compilers all share an optimizing code generator which employs optimization techniques found on mainframe compilers, as well as a parallelizing instruction scheduler that allows the XL's execution units to run in parallel.

For some algorithms (such as key graphics operations) code efficiency can be increased by returning to assembly code. These hand-coded routines can be linked with software modules written in a high-level language.

#### POSTSCRIPT-COMPATIBLE INTERPRETER

WEITEK supplies its HyperScript interpreter, a Post-Script-compatible interpreter that offers form, fit, function, and image compatibility with that offered by Adobe Systems, Inc. Users of the XL-8200 chip family gain a royalty-free right to object code.

WEITEK also supports third-party page description languages through development tools and optimized floating-point and graphics libraries.

The interpreter supports both Bitstream FontWare and URW's NIMBUS font-scaling software. Fonts are fully compatible with Adobe Font Metrics and are represented in Bezier outline form.

#### COMPLETE DEVELOPMENT SYSTEM SUPPORT

The design of an XL-Series-based product is simplified by the XL software and hardware development tools. The application programmer is able to develop and debug software on a VAX or PC/AT system with the XL-Series Software Development Environment, which includes a software simulator. For the hardware designer, complete engineering documentation is available.

The design of raster image processors is also facilitated by a graphics development system which is composed of a RIP board with the XL-8200, 3 Mbytes of page buffer and font memory, 256 kwords of code memory for the interpreter, PC/AT system interface, and Canon LBP-SX video interface card. This graphics development system provides a stable hardware environment on which PDLs can be debugged independently of the final target hardware.

#### **Design Requirements**

Several special steps must be taken to guarantee that your XL-8236 design will function correctly with present and future silicon. These steps must be taken if your design is to work correctly:

A latch, not a register, should be used to latch the code address (AC bus). Future XL-Series silicon may include an on-chip latch.

Coprocessor instructions are reserved for future expansion.

Memory-mapping should not be used: external register I/O should be used instead.

The special treatment of rfi0 and rfi1 must be implemented (see page 11).

The transfer data to RCS internal register instructions must be kept out of branch shadows and used only when interrupts are disabled. Set all fields marked " $\mathbf{x}$ " to zero in instructions which contain them. This assures that operations which are added in future designs will not modify the function of current instructions.

Pins marked "NC" (not connected) on the pin configuration diagram may be defined as *signal pins* in future enhancements to the RIP. Therefore, to preserve future upward compatibility, these pins should indeed be left unconnected.

Pins marked "TIE HIGH" or "TIE LOW" should be tied to VCC or GND. These pins may be redefined in the future as signal pins, in which case you may no longer want them tied high or low. Thus we recommend that they be tied through traces rather than directly to VCC or ground planes.

# **Absolute Maximum Ratings**

| Supply voltage                      | –0.5 to 7.0 V   |
|-------------------------------------|-----------------|
| Input voltage                       | 0.5 to Vcc      |
| Output voltage                      | –0.5 to 5.5 Vcc |
| Operating temperature range (TCASE) | 5° C to 125° C  |
| Storage temperature range65         | 5° C to 150° C  |
| Lead temperature (10 seconds)       | 300° C          |
| Junction temperature                | 175° C          |

Figure 39. Absolute maximum ratings

# **Recommended Operating Conditions**

| PABAMETER                                                                                                                                                               | CO        | UNIT |                           |                     |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------|---------------------------|---------------------|
|                                                                                                                                                                         | MIN       | NOM  | MAX                       | UNIT                |
| V <sub>CC</sub> Supply voltage<br>I <sub>OH</sub> High-level output current<br>I <sub>OL</sub> Low-level output current<br>T <sub>CASE</sub> Operating case temperature | 4.75<br>0 | 5.0  | 5.25<br>-1.0<br>4.0<br>85 | V<br>mA<br>mA<br>°C |

Figure 40. Recommended operating conditions

# DC Specifications

|                                    |                                                                                                     |                                                                                       | COMM     | ERCIAL        |      |  |
|------------------------------------|-----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|----------|---------------|------|--|
|                                    | PARAMETER                                                                                           | TEST CONDITIONS                                                                       | MIN      | MAX           | UNIT |  |
| VIH                                | High-level input voltage                                                                            | $V_{CC} = MIN$                                                                        | 2.0      |               |      |  |
| V <sub>IHC</sub>                   | High-level input voltage for<br>CLK only                                                            | $V_{CC} = MIN$                                                                        | 2.4      |               |      |  |
| V <sub>IL</sub>                    | Low-level input voltage                                                                             | $V_{CC} = MAX$                                                                        |          | 0.8           |      |  |
| VILC                               | Low-level input voltage for                                                                         | $V_{CC} = MAX$                                                                        |          | 0.8           |      |  |
| V <sub>OH</sub><br>V <sub>OL</sub> | CLK only<br>High-level output voltage<br>Low-level output voltage                                   | $V_{CC}$ = MIN, I <sub>OH</sub> = -1.0 mA<br>$V_{CC}$ = MIN, I <sub>OL</sub> = 4.0 mA | 2.8      | 0.4           | v    |  |
| I <sub>LI</sub><br>I <sub>LO</sub> | Input leakage current<br>Output leakage current<br>(output disabled)                                | $V_{CC} = MAX, V_{IN} = 0 - V_{CC}$<br>$V_{CC} = MAX, V_{OUT} = 0 - V_{CC}$           |          | ± 10<br>± 10  | μA   |  |
| 1 <sub>cc</sub>                    | Standby current                                                                                     | V <sub>CC</sub> = MAX, DC Conditions<br>TTL inputs                                    |          | 150           | mA   |  |
| I <sub>cc</sub>                    | Switching current                                                                                   | V <sub>CC</sub> = MAX, T <sub>CY</sub> = MIN<br>TTL inputs                            |          | 250           | mA   |  |
|                                    | Input capacitance <sup>†</sup><br>Clock capacitance <sup>†</sup><br>Output capacitance <sup>†</sup> | $T_{A} = 25 ° C$<br>f = 1 MHz<br>V <sub>CC</sub> = 5.0 V                              |          | 8<br>20<br>10 | pF   |  |
| † Cap                              | acitance not tested                                                                                 |                                                                                       | <b>.</b> |               |      |  |

Figure 41. DC specifications

**PRELIMINARY DATA** October 1988

# **AC** Specifications

0

| AC TEST CON                                                                             | DITIONS:                    |        |       |        |                                              |        |                                         |                     |                                                  |                                        |  |
|-----------------------------------------------------------------------------------------|-----------------------------|--------|-------|--------|----------------------------------------------|--------|-----------------------------------------|---------------------|--------------------------------------------------|----------------------------------------|--|
| $V_{CC} = MIN$                                                                          | $V_{IH} = 3.$ $V_{IL} = 0.$ |        |       |        | ', І <sub>ОН</sub> =<br>', І <sub>ОL</sub> = |        | 1                                       | T <sub>CASE</sub> = | $T_{CASE} = 85^{\circ}C$ $C_{LC}$                |                                        |  |
| DESCRIPT                                                                                |                             | XL-82  | 36-40 | XL-82  | 36-20                                        | XL-82  | 36-10                                   | SEE                 |                                                  |                                        |  |
| DECOM                                                                                   |                             | MIN    | мах   | MIN    | мах                                          | MIN    | ΜΑΧ                                     | FIGURE              | COMMENTS                                         |                                        |  |
| T <sub>CY</sub> CLK cycle t                                                             | me                          | 120    |       | 200    |                                              | 350    |                                         | 44,48               |                                                  |                                        |  |
| T <sub>CH</sub> CLK HIGH t                                                              | ime                         | 55     |       | 90     |                                              | 165    |                                         | 44,48               |                                                  |                                        |  |
| T <sub>CL</sub> CLK LOW ti                                                              | me                          | 55     |       | 90     |                                              | 165    |                                         | 44, 48              |                                                  |                                        |  |
| T <sub>R</sub> CLK rise tim                                                             |                             |        | 5     |        | 5                                            |        | 5                                       | 48                  |                                                  |                                        |  |
| T <sub>F</sub> CLK fall time                                                            |                             |        | 5     |        | 5                                            |        | 5                                       | 48                  |                                                  |                                        |  |
| T <sub>S1</sub> Set-up time<br>inputs<br>COND+, ST<br>EXT1-, EXT<br>EXT4-, RES<br>FPCN+ | ALL-,<br>'2-,               | 13     |       | 20     |                                              | 35     |                                         | 43                  |                                                  |                                        |  |
| T <sub>S2</sub> Set-up time<br>and AD[31.                                               | for code bus                | 25     |       | 30     |                                              | 35     |                                         | 43                  |                                                  |                                        |  |
| T <sub>S3</sub> Set-up time                                                             | for AD[20]<br>ddress gen-   | 35     |       | 40     |                                              | 45     |                                         | 43                  |                                                  |                                        |  |
| $T_{H1}$ Input hold ti<br>$T_{H2}$ Input hold ti                                        |                             | 3<br>5 |       | 3<br>5 |                                              | 3<br>5 |                                         | 43<br>43            | For all inputs except C bus<br>C bus inputs only |                                        |  |
| T <sub>1</sub> COND input                                                               | to AC valid                 |        | 40    |        | 60                                           |        | 80                                      | 43                  |                                                  | d STALL- are ex-<br>Iring TcL and are  |  |
| T <sub>2</sub> STALL- inp                                                               | ut to AC valid              |        | 40    |        | 60                                           |        | 80                                      | 43                  | thus not s                                       | pecified with re-<br>he rising edge of |  |
| T <sub>4</sub> EXT1-, EX<br>EXT4-, RE<br>input to AC                                    | SET-, FPCN+                 |        | 45    |        | 65                                           |        | 85                                      | 43                  | CER                                              |                                        |  |
| T5 CLK falling<br>Bus output                                                            | edge to AC                  |        | 65    |        | 100                                          |        | 150                                     | 43                  |                                                  |                                        |  |
| T6 CLK to AD4                                                                           | - turn-on                   | 15     |       | 15     |                                              | 15     |                                         | 43                  |                                                  |                                        |  |
| T7 AD+ bus tu                                                                           | rn-off time                 |        | 55    |        | 60                                           |        | 65                                      | 43                  |                                                  |                                        |  |
| T8 CLK to AD+                                                                           |                             |        | 95    |        | 160                                          |        | 300                                     | 43                  |                                                  |                                        |  |
| T9 CLK to OP4                                                                           |                             |        | 35    |        | 55                                           |        | 70                                      | 43                  |                                                  | instruction combi-<br>e avoided.       |  |
| T9A CLK to OP4                                                                          | - valid                     |        | 55    |        | 65                                           |        | 85                                      | 43                  |                                                  | ase. See p. 67                         |  |
| T11 CLK to NEU                                                                          | JT- valid                   |        | 40    |        | 60                                           |        | 80                                      | 43                  |                                                  |                                        |  |
| $T_{VO}$ Output valid                                                                   | time                        | 5      |       | 5      |                                              | 5      |                                         | 43                  |                                                  |                                        |  |
| T <sub>ZO</sub> Output enab                                                             | le time                     |        | 30    |        | 40                                           |        | 50                                      | 45                  |                                                  |                                        |  |
| T <sub>OZ</sub> Output disal                                                            | ole time                    |        | 30    |        | 40                                           |        | 50                                      | 45                  |                                                  |                                        |  |
| All units in nanose                                                                     | econds                      |        |       |        |                                              |        | • • • • • • • • • • • • • • • • • • • • |                     | <b>-</b>                                         |                                        |  |

Figure 42. AC specifications: guaranteed switching characteristics over commercial temperature range and operating conditions. Contact your WEITEK sales representative for XL-8236-60 specifications

# **Timing Description**



Figure 43. Timing diagram

#### PRELIMINARY DATA October 1988

#### **Timing Description, continued**

Signal timing is shown in figure 43. At the beginning of clock cycle 1, an instruction is received from the edge-triggered code register connected to the C bus and executed. If the instruction is a transfer from the RCS, the AD bus is driven by an internal register at time  $T_8$  after the start of the cycle. If the instruction is a transfer to the RCS, the data is received by an edge-triggered register on the AD bus at the end of the cycle. The AD output drivers have an turn-on time from the CLK edge of  $T_6$ .

If the previous instruction is a taken branch, the b bit of the .ssr will be set. This can activate the NEUT-output line on the current instruction cycle at time  $T_{11}$ , after the beginning of the cycle.

The OP outputs are driven at  $T_9$  or  $T_{9A}$ . The timing for  $T_9$  assumes that certain instruction combinations will not be used in the code; specifically, that load, store, rfi0, input, and output instructions will never be placed either in the shadow of a flow-of-control instruction or at the target of a flow-of-control instruction. The T<sub>9A</sub>

specification assumes that no such care is taken. Transfer-of-control instructions include br, shbr, brstkp, endloop, sob, shsob, brp, bsr, and rts; any instruction that causes the program counter to do anything besides increment is a transfer-of-control instruction. The clocking of the external AD bus register on the RIP must work with the general (slower) case.

The XL-Series compilers never generate code that violates this rule. A program to check for violations of this rule in user-written assembly-code routines is included with the XL-8200 development system.

The code address which appears on the AC bus depends upon a number of control inputs and settles at times  $T_1$ ,  $T_2$ ,  $T_4$ , or  $T_5$  after the corresponding control input is changed. These control inputs are received by level-sensitive latches that are transparent during the second part of the cycle. These control inputs include EXT1-, EXT2-, EXT4-, RESET-, STALL-, COND+, and FPCN+.



Figure 44. Clock timing



Figure 45. Tri-state timing









Figure 47. Input and Output Equivalent Circuits



Figure 48. Clock timing

**PRELIMINARY DATA** October 1988

# Pin Configuration

C

| 15   | C31      | C27  | C23  | C22        | C20                     | C16         | C15   | C12   | C10    | C9          | C6          | СЗ    | C1         | vcc  | NC   |   |
|------|----------|------|------|------------|-------------------------|-------------|-------|-------|--------|-------------|-------------|-------|------------|------|------|---|
| 14   | vcc      | C30  | C26  | C24        | C21                     | C18         | C17   | C11   | C7     | C5          | C2          | GND   | GND        | vcc  | AD1  |   |
| 13   | AD30     | GND  | C29  | C28        | C25                     | C19         | C14   | C13   | С8     | C4          | C0          | GND   | AD0        | AC1  | AD3  |   |
| 12   | AD29     | AD31 | NC   |            |                         |             | AC0   | AC2   | АСЗ    |             |             |       |            |      |      |   |
| 11   | NC       | NC   | NC   |            | <b></b>                 | <del></del> | AD2   | AD4   | AC4    |             |             |       |            |      |      |   |
| 10   | AD26     | AD28 | NC   |            |                         |             |       |       |        |             |             |       |            |      | AC6  |   |
| 9    | NC       | AD27 | NC   |            | XL-8236                 |             |       |       |        |             |             |       |            |      | GND  |   |
| 8    | vcc      | GND  | AD25 |            | Top View<br>(cavity up) |             |       |       |        |             |             |       |            | AC7  | AD7  |   |
| 7    | AD24     | AD23 | NC   |            |                         |             |       |       |        |             |             |       |            | AC9  | AD8  |   |
| 6    | NC       | NC   | AD22 |            |                         |             |       |       |        |             |             |       | AD11       | AC10 | AC8  |   |
| 5    | NC       | AD21 | AD19 |            | [                       | <u></u>     | ····· |       |        |             |             |       | AD13       | AD12 | AD10 |   |
| 4    | AC21     | AC20 | GND  | KEY<br>PIN |                         |             |       |       |        |             |             |       | GND        | AC13 | AC11 |   |
| 3    | AD20     | AC19 | vcc  | NC         | AC17                    | AC15        | OP2   | NC    | STALL- | TIE<br>HIGH | vcc         | OEAD- | TIE<br>LOW | AC14 | AC12 |   |
| 2    | GND      | GND  | AD18 | AD17       | AC16                    | GND         | OP1   | NC    | COND   | NC          | RESET       | GND   | vcc        | vcc  | AD14 |   |
| 1    | NC       | AC18 | AD16 | AD15       | OP0                     | OP3         | OP4   | NEUT- | EXT1-  | FPCN        | TIE<br>HIGH | EXT2- | EXT4-      | CLK  | NC   |   |
|      | A        | В    | с    | D          | E                       | F           | G     | Н     | J      | к           | Ļ           | м     | N          | Р    | R    | , |
| Note | : Pins n |      |      | t be lef   | t uncon                 | nected      |       |       |        |             |             |       |            |      |      |   |

Figure 49. Pin configuration





Figure 50. XL-8236 physical dimensions

#### PRELIMINARY DATA October 1988

# **Ordering Information**

| PACKAGE TYPE        | SPEED GRADE | TEMP. RANGE (CASE)                       | ORDER NUMBER    |
|---------------------|-------------|------------------------------------------|-----------------|
| 145-pin plastic PGA | -10         | T = 0 to +85°C                           | XL-8236-010-GPU |
| 145-pin plastic PGA | -20         | T = 0 to +85°C                           | XL-8236-020-GPU |
| 145-pin plastic PGA | -40         | T = 0 to +85°C                           | XL-8236-040-GPU |
| 145-pin plastic PGA | -60         | T = 0 to +85°C                           | XL-8236-060-GPU |
| PACKAGE TYPE        | SPEED GRADE | TEMP. RANGE (CASE)                       | ORDER NUMBER    |
| 145-pin ceramic PGA | -10         | $T = 0 \text{ to } +85^{\circ} \text{C}$ | XL-8236-010-GCU |
| 145-pin ceramic PGA | -20         | T = 0 to +85°C                           | XL-8236-020-GCU |
| 145-pin ceramic PGA | -40         | T = 0 to +85°C                           | XL-8236-040-GCU |
| 145-pin ceramic PGA | -60         | T = 0 to +85°C                           | XL-8236-060-GCU |

Figure 51. Ordering information

# **Revision Summary**

T7 was corrected in figure 43

Input hold times increased from 3 ns to 5 ns

The -60 part grade is now available

The package designator for plastic parts in the order number changed from "PGCU" to "GPU"

Figure 52. Revision summary

#### Index

#### Symbols

.brk register. See breakpoint register .cea register. See registers, address .cfa register. See registers, address .ifa register. See registers, address .ssr. See sequencer status register .tim asrtadr, 16

#### A

AC bus, 3 AC specifications, 65 AD bus, 3 architecture, 5-6

# B

b (bit in .ssr). See sequencer status register (.ssr)
bi (bit in .ssr). See sequencer status register (.ssr)
block diagram, 1, 2
branch shadow, 9
breakpoints, 8
buses, 5

# С

C bus, 3 CLK, 3 COND, 4 Condition, floating point, 16 clocks, CLK, 3 control flow, 5, 6

# D

DC specifications, 64 delayed branching, 9 dimensions, 70

#### $\mathbf{E}$

EXT1- through EXT4-. See interrupts exceptions, 6, 14 See also interrupts breakpoint, 14 overflow, 6, 14, 15 timer. See interrupts, timer traps, 14, 16 underflow, 6, 14, 15 watchpoint, 14

#### F

FPCN, 4, 16 FPU, 16

# G

GND, 4

# I

I/O characteristics, 68 Interrupts, Nested, 17 infinite loop. See loop, infinite instruction interaction, 57-60 branching, 57 calls and returns, 58 interrupts, 60 looping instructions, 59 instruction set, 5 instructions, 19 br, 24 branch, 23-27 brc, 27 brp, 33 brstkp, 26 bsr, 35 continue, 22 data transfer, 46-55 endloop, 30 format, 19 interrupt control, 37-38 loop, 28-33 mov, 46, 47, 48, 49, 51, 53, 54, 55, 56 neutralization, 41-45 ovneut, 43 ovneuti, 44

pops, 50 pushs, 52 revneut, 45 rfi0, 38 rfi1, 39 rts, 36 shbr, 25 shsob, 32 sob, 31 subroutine, 34-36 terms and symbols, 19 trap, 40 See also exceptions, traps trapi, 40 interrupts, 5, 10-17, 62 See also exceptions enable bits (in .ssr), 7 external, 3, 14 flag bits (in .ssr), 7, 13 handling, 16, 17 internal. See exceptions sequence, 10 timer, 8, 14

# L

Latency, 16 loop, infinite. See infinite loop

# $\mathbf{M}$

memory control, 61, 62

#### Ν

NC, 4 NEUT-, 3, 9 Nested interrupts, 17 neutralization, 9 See also NEUT-

# 0

OEAC-, 4 OEAD-, 4 OP bus, 3, 61-62 ordering information, 71 overflow. See exceptions, overflow

# PRELIMINARY DATA

October 1988

#### Index, continued

# P

PSU. See program sequencing unit packaging, 1-3 physical dimensions, 70 pin configuration, 69 pipelining, 5 power-up, 5, 6 program sequencing unit (PSU), 1

# R

RESET-, 3 recommended operating conditions, 64

registers, 7-8 address (.cea, .cfa, and .ila), 7 breakpoint (.brk), 8 interrupt address, 10 interrupt base (.ibr), 10 timer (.tim), 8 reset, 5, 6, 7, 18 rf10, Bug, 16

# S

STALL-, 4, 5, 10, 12 Stack overflow, 17 s (bit in .ssr). See sequencer status register (.ssr) sequencer status register (.ssr), 6, 7, 8, 13, 18 modifying, 7 signal description, 3-4 signals, bus enable/disable, 4 specifications AC, 65 absolute maximum ratings, 64 DC, 64 physical dimensions, 70 pin configuration, 69 recommended operating conditions, 64 stack, 6, 15

# Т

Timer, 16 Timing, 66-67 top-of-stack register (.tos), 6, 7 traps. See exceptions, traps

# U

underflow. See exceptions, underflow

#### V

VCC, 4

Χ

XL-3232, 16



For additional information on WEITEK products, please fill out the form below and mail.

|                                            | Phone                                                                                                                         |                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                            |                                                                                                                               |                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                            |                                                                                                                               |                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                            |                                                                                                                               |                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| he following Weitek products atus updates. |                                                                                                                               |                                                                                                                                                                                                                          | and wish to                                                                                                                                                                                                                                                                                                                                                                                     | be added to your                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                            |                                                                                                                               |                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                            | SCIENTIFIC COM                                                                                                                | IPUTERS                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                            | OTHER                                                                                                                         |                                                                                                                                                                                                                          | _                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                            |                                                                                                                               |                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| receive data sheets:                       |                                                                                                                               |                                                                                                                                                                                                                          | 🗆 Have a                                                                                                                                                                                                                                                                                                                                                                                        | sales person call                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| COPROCESSORS                               | BUILDING BLOCKS                                                                                                               | 5                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| □ 1167                                     | 2264/2265                                                                                                                     | 🗋 1066                                                                                                                                                                                                                   | 2516                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1164/1165                                  | 3132/3332                                                                                                                     | 2010                                                                                                                                                                                                                     | 2517                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3164/3364                                  | □ 1232/1233                                                                                                                   | □ 2245                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3167                                       |                                                                                                                               |                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                            |                                                                                                                               |                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Out                                        |                                                                                                                               | ТРТ                                                                                                                                                                                                                      | Sour                                                                                                                                                                                                                                                                                                                                                                                            | ce: DS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                            |                                                                                                                               |                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                            | atus updateš.         receive data sheets:         COPROCESSORS         1167         1164/1165         3164/3364         3167 | atus updateš.       SCIENTIFIC COM         OTHER       OTHER         receive data sheets:       BUILDING BLOCKS         1167       2264/2265         1167       3132/3332         3164/3364       1232/1233         3167 | atus updateš.          SCIENTIFIC COMPUTERS <ul> <li>OTHER</li> <li>OTHER</li> </ul> receive data sheets:           COPROCESSORS           BUILDING BLOCKS           1167         2264/2265           1167         2264/2265           1167         2264/2265         1066           1164/1165         3132/3332         2010           3164/3364         1232/1233         2245           3167 | SCIENTIFIC COMPUTERS         OTHER         OTHER         receive data sheets:         Image: Coprocessors         BUILDING BLOCKS         Image: |

# WEITEK XL-8236 22-BIT RASTER CODE SEQUENCER Please Comment On The Quality Of This Data Sheet.

Even though we have tried to make this data sheet as complete as possible, it is conceivable that we have missed something that may be important to you. If you believe this is the case, please describe what the missing information is, and we will consider including it in the next printing of the data sheet.



Fold, Staple and Mail to Weitek Corp.



# **BUSINESS REPLY MAIL**

FIRST CLASS PERMIT NO. 1374 SUNNYVALE, CA

POSTAGE WILL BE PAID BY ADDRESSEE

WEITEK Corporation 1060 E. Arques Ave. Sunnyvale, CA 94086-BRM-9759

ATTN: Ed Masuda



# WEITEK

#### WEITEK'S CUSTOMER COMMITMENT:

Weitek's mission is simple: to provide you with VLSI solutions to solve your compute-intensive problems. We translate that mission into the following corporate objectives:

- 1. To be first to market with performance breakthroughs, allowing you to develop and market systems at the edge of your art.
- **2.** To understand your product, technology, and market needs, so that we can develop Weitek products and corporate plans that will help you succeed.
- **3.** To price our products based on the fair value they represent to you, our customers.
- **4.** To invest far in excess of the industry average in Research and Development, giving you the latest products through technological innovation.
- 5. To invest far in excess of the industry average in Selling, Marketing, and Technical Applications Support, in order to provide you with service and support unmatched in the industry.
- **6.** To serve as a reliable, resourceful, and quality business partner to our customers.

These are our objectives. We're committed to making them happen. If you have comments or suggestions on how we can do more for you, please don't hesitate to contact us.

Art Collmeyer President

#### Headquarters

Weitek Corporation 1060 E. Arques Avenue Sunnyvale, CA 94086 TWX 910-339-9545 WEITEK SVL FAX (408) 738-1185 TEL (408) 738-8400

#### **Domestic Sales Offices**

Weitek Corporation 1060 E. Arques Avenue Sunnyvale, CA 94086 TWX 910-339-9545 WEITEK SVL FAX (408) 738-1185 TEL (408) 738-8400 Corporate Place IV 111 South Bedford St. Suite 200 Burlington, MA 01803 FAX (617) 229-4902 TEL (617) 229-8080

#### **European Sales Headquarters**

Greyhound House, 23/24 George St. Richmond, Surrey, TW9 1JY England TELEX 928940 RICHBI G FAX 011-441 940 6208 TEL 011-441 549 0164

#### Japanese Representative

4-8-1 Tsuchihashi Miyamae-Ku Kawasaki, Kanagawa-Pre 213 Japan FAX 044-877-4268 TEL 044-852-1135