## TEXAS INSTRUMENTS

## 9900

## SBP9989

Advance 16 Bit $^{2}$ L Microprocessor

MICROPROCESSOR SERIES**

Data Manual

Texas Instruments . . . the inventor of the integrated circuit, the microprocessor, and the microcomputer . . . is a leader in the technology that provides electronic sensing, control, computing, and even speech. For additional information on TI's high-technology products contact:

Military Products Marketing Group<br>Texas Instruments Incorporated<br>P.O. Box 6448, MS 3030<br>Midiand, Texas 79701<br>(915) 685-7142<br>or<br>Customer Response Center<br>Texas Instruments Incorporated<br>P.O. Box 225012, MS 57<br>Dallas, Texas 75265<br>(214) 995-6611

## IMPORTANT NOTICES

Texas instruments reserves the right to make changes at any time in order to improve design and to supply the best product possible.

TI cannot assume any responsibility for any circuits shown or represent that they are free from patent infringement

## SBP9989 MICROPROCESSOR <br> TABLE OF CONTENTS

INTRODUCTION ..... 3
The 9900 Family ..... 3
The S8P9989 ..... 3
KEY FEATURES ..... 3
DEVELOPMENT SUPPORT ..... 4
AMPL System Advanced Microprocessor Prototyping Lab ..... 4
Transportable Assembier ..... 4
12 L TECHNOLOGY ..... 6
COMPATIBILITY WITH SBP9900A SYSTEMS ..... 8
Hardware ..... 8
Software ..... 8
OEVICES FOR MILITARY TEMPERATURE APPLICATIONS ..... 8
PIN ASSIGNMENTS AND FUNCTIONS ..... 12
ARCHITECTURE AND TIMING ..... 16
FUNCTIONAL DESCRIPTION ..... 16
Block Diagram ..... 16
Arthmetic Logic Unit ..... 16
Internal Registers ..... 17
Program Counter ..... 17
Status Register ..... 18
Workspace ..... 18
Workspace Pointer ..... 18
Context Swithing ..... 18
INTERFACES ..... 20
Memory interfaces ..... 20
HOLD, DMA interfaces ..... 22
Extended instruction Processor Interface ..... 23
Multiprocessor Interlock ..... 25
INTERRUPTS. ..... 26
Interrupt Level 0 - RESET ..... 28
Interrupt Level 2 ..... 28
Undefined Op-Code Trap ..... 29
Communication Register Unit Interface ..... 29
Single-Bit CRU Operation ..... 31
Multıple-Bit CRU Operation ..... 32
External Instructions ..... 33
LOAD Function... . ..... 33
STANDARD INSTRUCTION SET ..... 34
Terms and Definitions ..... 34
ADDRESSING MODES ..... 35
STATUS REGISTER MANIPULATION ..... 38
INSTRUCTIONS ..... 40
Dual-Operand Instructions with Multiple Addressing for Source and Destination Operands ..... 40
Dual-Operand Instructions with Multiple Addressing for Source Operand and Workspace Register Addressing for the Destination ..... 41
Signed Multiply and Divide instructions ..... 42
Single-Operand Instructions ..... 43
CRU Multiple-Bit Instructions ..... 44
CRU Single-Bit Insiructions ..... 44
Jump instructions ..... 45
INSTRUCTIONS icontinued
Shift Instructions ..... 46
Immediate Register Instructions ..... 46
Internal Register Laad Immediate instructions ..... 47
Internal Register Load and Store Instructions ..... 47
Extended Operation Instruction ..... 47
Return Workspace Pointer Instructions ..... 48
External Instructions ..... 48
Microinstruction $\mathrm{Cyc}^{1}$ ..... 48
Instruction Execution Times ..... 49
MACHINE CYCLES ..... 52
ALU Cycle ..... 52
Memory Cycle ..... 52
CRU Cycle ..... 52
9989 MACHINE CYCLE SEQUENCES ..... 53
Data Derivation Sequence ..... 53
Workspace Register ..... 53
Workspace Register indirect ..... 53
Workspace Register Indirect Auto-Increment ..... 53
Symbolic ..... 53
Indexed ..... 53
INSTRUCTION EXECUTION SEQUENCE ..... 54
A AB MOVB S SB SOC SOCB SZC SZCB ..... 54
ABS ..... 54
AI ANDI OR ..... 54
B ..... 54
BL ..... 54
BLWP ..... 54
C CE COC CZC ..... 54
Cl ..... 54
CKOF CKIR LREX IDLE RSET ..... 54
CLR ..... 54
DEC,DECT INC INCA SWPB ..... 54
DIV,DIVS ..... 55
ILLOP JUMPS ..... 55
LDCR LI, LIMI,LWP ..... 55
LOAD INTERRUPT CONTEXT SWITCH ..... 56
LST,LWP ..... 56
MDV ..... 56
MPY(signed) . ..... 56
NEG. . ..... 56
RESET RTWP ..... 56
SBO.SBZ.TB ..... 56
SETO.SHIFTS ..... 57
STCR ..... 57
STST,STWP. . ..... 57
$X$ ..... 57
XOR ..... 57
XOP ..... 57
Leaving a Hold Siate ..... 58
PROCESSING ..... j2
POWER SOURCE ..... 59
ELECTRICAL DATA ..... 60
Input 'Outplit Structure ..... 60
MECHANICAL DATA ..... 63

## INTRODUCTION

## The 9900 Family

The 9900 Family is a compatible set of microprocessors, microcomputers, microcomputer modules, and minicomputers. It is supported with peripheral devices, development systems, and software and provides the designer with a system solution that has built-in protection against technological obsolescence. The family features true software compatibility, I/O bus compatıbility and price/performance ratios which encompass a wide range of applications. The family is designed with a unique flexible architecture to allow technological changes to be easily incorporated while minimizing the impact these changes have on an overall system design

## The SBP9989 I2L 16-Bit Microprocessor

The SBP9989 is a second-generation, bipolar 16 bit microprocessor offering twice the performance of the original SBP9900A Implemented in TI's Advanced I2L Technology, the S8P9989 combines environmental ruggedness and therent reliability with a 16 -bit word length, an advanced memory-to-memory architecture, and a full mimicomputer instruction set to extend the end application reach of the Texas Instruments 9900 microprocessor family into those applications requiring efficient, stable, reliable performance in severe operating conditions

The instruction set of the SBP9989 includes the capabilities offered by full minicomputers and is a superset of the 9900 instruction repertoire The SBP9989 can be used to upgrade existing SBP9900A systems or to implement new system designs requiring the increased through-put and doubled memory capability

## KEY FEATURES

The SBP9989 is downward-compatible with all of Ti's existing microcomputer and minicomputer products and employs the advanced, memory-to-memory architecture that ensures optimal performance in the structured, I/O-intensive applications of the 80's.

- Memory-to-memory architecture
- $\quad 73$ basic instructions include all 69 instructions of the SBP9900A plus Signed Multıply, Signed Divide, Load WP, and Load ST The signed multiply and divide instructions allow significant improvements in system through-put in numerical applications, while load workspace register and load status register are essential to the efficient implementation of advanced operating systems.
- User extension to the basic instruction set allows undefined op codes to be assigned meanings during system design. The processor detects undefined op codes in an instruction stream and allows either software interpretation and execution of the code or hardware execution in special, user-designed "attached processors". Coordination between the SBP9989 and its attached processors is achieved via a new input signal to the microprocessor designated XIPP (External Instruction Processor Present).
- Direct access to 128 kilobytes of memory from the SBP9989 is provided by a new output signal designated MPEN (Memory Map Enable) which can be used directly as an additional address bit from the processor. This bit is represented in the processor Status Register as Status 8it 8, which may be manipulated by the user to allow access to two 64 -kılobyte pages of memory. $\overline{M P E N}$ can also be used with the SN54LS610 Memory Mapper to allow access to as much as 16 megabytes of memory. All traps cause Status Bit 8 to be forced to zero during a context switch, ensuring consistent interrupt operation and full software and hardware compatibility with other TI products.
- Multiprocessor system features allow coordination between several processing elements that must share memory and other resources. These features include:

MPILCK (Multiprocessor Interiock), a new output signal that allows a processor to secure and hold a system resource against possible access contention with other processing elements.

INTACK (Interrupt Acknowledge), a new output signal which allows the SBP9989 to acknowledge the presence of an interrupt during those times when it may not have control of the system resources.
$\overline{\text { XIPP }}$ (Extended Instruction Processor Present), a new input signal that establishes a protocol for orderly transfer of bus control between host and slave processors that share memory resources.
LOAD WP and LOAD ST (Load Wbrkspace Pointer and Load Status Register) instructions that allow the SBP9989 to capture a complete software context from an external source.

- Fully static design allows the SBP9989 to be clocked up to 44 MHz , or single stepped The TTL-compatible 1/O permits any standard logic and memory devices to be used
- Simplified clock requirements consist of a single-phase clock with a $50 \%$ duty cycle
- Improved microcode within the processor enhances the efficiency of the SBP9989 over its predecessors. Micro cycles were removed from more than half of the instructions, resulting in a $15 \%$ to $20 \%$ improvement in operating efficiency.
- Fully implemented 16-bit status register with Arithmetic Overfow Interrupt trap
- Improved external instruction, utilizing five address lines, provides a total of 160 forms avalable to the user.
- Improved HOLD and WAIT interfaces.
- Implemented in Advanced 12L . . a proven bipolar technology for high-reliability applications.

The single most important feature of the SBP9989, and alf of Ti's microprocessors, is its memory-to-memory concept. The user has access to an unlimited number of effective registers, and may completely change register context (an operation equivalent to sixteen push and sixteen pop stack operations in a conventional registered architecture) in fust five memory cycle times The ability to change register content rapidly becomes of prime importance in systems that rely on multiprocessor architectures and high-level languages for efficient software. trends which will gain momentum as embedded computer applications become increasingly more complex

## DEVELOPMENT SUPPORT

## AMPL System Advanced Microprocessor Prototyping Lab

The AMPL System is a complete set of software and hardware tools that maximize software productivity for the 9900 family It includes a video display terminal, multiuser hard disk or floppy diskette options, and extensive software Programs can be edited, assembled, loaded, and executed with easy self-prompting commands.

The AMPL System supports software development as well as in-circuit emulation for existing 9900 family CPU's. The logic state trace capability features interactive on line control and analysis to provide fast data reduction, and programmable emulation control based on the result of this analysis. The high-level language has designed-in features to simplify onentation for the new user while providing extensive flexibility and support for the expenienced user.

PROM programming implements target-system memory in PROM and EPROM while the AMPL interactive process makes it easy to identify and implement needed design changes.

## Transportable Assembler

The SBP9989 is supported by a transportable general assembler (TI part numberTMAM4015). This assembler allows the use of symbolic instructions and assembler directives supporting the full instruction set. The 9900 family instruction set is composed of a base set of 69 instructions plus extensions peculiar to each CPU which provide the input and output manipulation comparison of words and bytes, and ASCli-character data This product can be executed in TI 990, IBM, or DEC environments

## 12L TECHNOLOGY

12L is an integrated-injection circuit logic where current steering is used to control gate switching levels A lateral PNP transistor is used as an injector to supply base current to the vertical NPN transistor as shown in the figure. The NPN actually serves as the gate that is controlled by placing either a high or low voltage on the base that steers the injector current into or out of the NPN base

12L technology provides inherent advantages to the user when compared to other technologies.

- $\quad-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Temperature Range

Circuits are designed to operate over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ rather than fust being selected by screening. This provides added design margin that enhances system reliability.
o Low Power Consumption
The SBP9989 dissipates less than 0.75 watts, depending upon the state of the I/O's.

## o Radiation Hardness

Also inherent with ${ }^{2} \mathrm{~L}$ as used on the SBP9989 is tolerance to radiation Its tolerance to transient upset is among the best observed on LSI parts while the simplicity of the process eliminates latch-up.

## o Low Internal Stress Voltage

High internal voltages have been eliminated with 12 L , thereby assuring further gams in reliability. The 5,000 internal gates of the SBP9989 are stressed only with the $V_{\text {INJ }}$, which is typically 1.2 volts. Oniy the inputs and outputs are exposed to high stress voltages.

- High Reliability

The SBP9989 has been designed, fabricated and $100 \%$ screened with processes to assure the highest levels of reliability. Each part is individually identified to assure traceability


## $1^{2}$ L CIRCUIT SCHEMATIC



12ldevice structure

The SBP9989 is pin for pin compatible with the SBP9900A except for 4 new I/O controls (MPEN, INTACK, MPILCK and $\overline{X(P P)}$ assigned to pins that were not used on the original device The modifications required to plug an SBP9989 into an existing SBP9900A socket are listed below

## Hardware

- Deactivating $\overline{\text { XIPP }}$ (tie Pin 58 to $V_{C C}$ through a pull up resistor)
- Provision for an increase in injector voltage to 125 V and a reduction in injector current to 400 mA
- Verifyıng that $P_{i n} 25$ (MPEN), $P_{i n} 37$ (INTACK), and $P_{i n} 39$ (MPILCK) are open of grounded
o Interiupt lines sampled during hold and non hold states

o The READY input signal (pin 62) needs to be active during CRU transactions to avold walt states
o Automatic wait states are typically generated with the SBP9900A by tying the wat output signal back into the READY input. However, unlike the SBP9900A, the SBP9989 will continue to generate wait signals during a HOLD operation To eliminate the unwanted wait signals during HOLD operations, the HOLDA and WAIT output signal lines can be OR-ed to drive the READY input line


## Software

- Although software written for the SBP9900A can be executed by the SBP9989, a reduction of $15^{\circ}$ o to $20^{\circ}$ in execution time should be anticipated Software timing loops will need new time constants to compensate for the reduced execution times
- Any unused op codes used as NOP's in the SBP9900A software will cause the SBP9989 to execute a level 2 interrupt trap
o Status bit 10 set to 1 will enable the arithmetic overflow detection trap


## DEVICES FOR MILITARY TEMPERATURE APPLICATIONS

The SBP9989 is a member of the ever growing family of military microprocessor components

| SBP9989 | 16 Bit Advanced $\mathrm{H}_{1}$ Rel Microprocessor |
| :---: | :---: |
| SBP9900A | 16-Bit $\mathrm{H}_{1}$-Rel Microprocessor |
| SBP9965 | Peripheral Interface Adapter |
| SBP9901 | Programmable Systems Interface (in design) |
| SNJ54LS244 | Octal Buffer Line Driver/Line Receiver |
| SNJ54LS373 | Octal D-Type Transparent Latch |
| SNJ54LS374 | Octal D Type Edge-Triggered Flip-Flop |
| SNJ54LS610 | Memory Mapper (future product) |
| SNJ54LS629 | Dual Voltage Controlled Oscillator |
| SNJ54LS630 | 16-Bit Parallel Error Detection and Correction Unit |
| SNJ54LS644 | Octal Bus Transceiver |
| SNJ54LS645 | Octal Bus Transceiver |
| SNJ54LS673 | 16-Bit Shift Register |
| SNJ54LS674 | 16 Bit Shift Register |
| SNJ54S189 | 64 Bit (16 x 4) RAM |
| JBP24S10 | 1024-Bit ( $256 \times 4$ ) PROM |
| JBP18S030 | 256 Bit ( $32 \times 8)$ PROM |
| JBP28S46 | 4096 Bit ( $512 \times 8$ ) PROM |
| JBP28L86 | 8192-Bit (1024 $\times 8$ ) PROM |
| JBP28S86 | 8192 -Bit (1024 $\times 8$ ) PROM |

## FLOW CHART




SBP9989NJD
64-PIN CERAMIC SIDE BRAZED PACKAGE (TOP VIEW)


SBPG989NFD
68 TERMINAL CERAMIC CHIP CARRIER (TOP VIEW)


| SIGNATURE | PIN \# | 1/0 | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\overline{M P E N}$ | $\begin{gathered} 24 \\ 10 \\ 25 \end{gathered}$ | OUT* <br> OUT* | ADDRESS BUS <br> A0.A14 comprise the address bus This open-collector bus provides the memory address to the memory system when MEMEN is active and CRU I/O bit addresses to the I/O system when MEMEN is inactive and DBIN is active <br> MEMORY MAP ENABLE MPEN represents the inverted value of Status Register Bis 8 (ST8) $\overline{M P E N}$ can be changed by any instruction (i e, LST, etc) affecting ST8 and will be set to 1 during SBP9989 trap addressing, namely interrupts, $\overline{\text { LOAD }}$, RESET, XOP and ILLOP, MPEN may be used to allow memory expansion to 64 kilowords |
|  | $\stackrel{41}{56}$ | $1 / 0^{*}$ | DATA BUS <br> D0-D15 comprise the bidirectional, open-collector data bus This bus transfers memory data to (when writing) and from (when reading) the external memory system when MEMEN is active |
| INJ <br> INJ <br> INJ <br> INJ <br> GND <br> GND <br> GND <br> GND | $\begin{array}{r} 9 \\ 26 \\ 40 \\ 57 \\ 1 \\ 2 \\ 27 \\ 28 \end{array}$ |  | POWER SUPPLY <br> Injector-Supply Current <br> Injector-Supply Current <br> Injector-Supply Current <br> Injector-Supply Current <br> Ground <br> Ground <br> Ground <br> Ground |
| CLK | 8 | IN | CLOCK <br> Single-phase clock input |
| MEMEN <br> DBIN | $63$ $29$ | OUT* <br> OUT* | BUS CONTROL <br> MEMORY ENABLE When active (low), MEMEN indicates that the address bus contains a valid memory address <br> DATA BUS 1 N When activated (high) by the SBP9989 during MEMEN, DBIN indicates that the SBP9989 has disabled its output buffers to allow the memory system to place memory read data on the bus The SBP9989 will also activate DBIN during all CRU operations and during the execution of the five external instructions. In all other cases except when HOLDA is active, the SBP9989 will marntain DBIN at a low logic level |
| $\overline{W E}$ | 61 | OUT* | WRITE ENABLE When active (low), $\overline{W E}$ indicates that the SBP9989 data bus is outputting data to be written into memory |

[^0]\begin{tabular}{|c|c|c|c|}
\hline SIGNATURE \& PIN \({ }^{\text {\% }}\) \& \(1 / 0\) \& DESCRIPTION \\
\hline \begin{tabular}{l}
CRUCLK \\
CRUIN \\
CRUOUT
\end{tabular} \& 60
31

30 \& OUT \& | COMMUNICATION REGISTER UNIT (CRU) |
| :--- |
| CRU CLOCK When active (high), CRUCLK indicates to the external logic the presence of output data on CRUOUT or the presence of an encoded external instruction on A0 A2 |
| CRU DATA IN CRUIN recerves input data from the external interface logic When the SBP9989 executes a STCR or TB instruction, it samples CRUIN for the level of the CRU bit specified by the address bus (A3 A14) |
| CRU DATA OUT CRUOUT outputs serial data when the SBP9989 executes a LDCR, SBZ, or SBO instruction The data on CRUOUT should be sampled by the external interface logec when CRUCLK goes active | <br>

\hline $\overline{I N T R E Q}$ \& 32 \& IN \& | INTERRUPT CONTROL |
| :--- |
| INTERRUPT REQUEST When active (low), INTREO indicates that an external interrupt is requesting service If INTREQ is active the SBP9989 toads the data on the interrupt code input lines $1 \mathrm{CO} \mathrm{IC3}$ into the internal interrupt-code storage register The code is then compared to the interrupt mask bits of the status register If the interrupt code is equal to or less than Status Register Bits 1215 (equal of higher prionty than the previous enabled interrupt level\}, the SBP9989 initates the interrupt sequence if the comparison falls, the SBP9989 ignores the interrupt request In that case, INTREQ should be held active The SBP9989 will contunue to sample ICOIC3 until the program enables a sufficiently low interrupt level to accept the requesting interrupt | <br>

\hline  \& $$
\left.\right|_{33} ^{36}
$$ \& IN \& INTERRUPT CODES ICO (MSB) IC3 (LSB), indicating an interrupt identity code, are sampled by the SBP9989 when INTREQ is active (low) When ICO-IC3 are LLLL, the highest-priority external interrupt is requesting service, when HHHH , the lowest-priority external interrupt is requesting service <br>

\hline INTACK \& 37 \& OUT \& INTERRUPT ACKNOWLEDGE When active (high) during non-hold states, INTACK indicates the SBP9989 has intiated a trap sequence caused by the recept of a valid interrupt, $\overline{\text { LOAD }}$ or $\overline{\text { RESET }}$ INTACK shail be activated in the trap sequence while the SBP9989 is obtarning the new WP value from memory An external device may determine which function or interrupt level is being serviced by monitoring the address bus during the INTACK time When the SBP9989 is in a hold state (caused by activation of XIPP or $\overline{\text { HOLD }}$ INTACK indicates SBP9989 has received a valid interrupt (level is less than value of interrupt mask), a $\overline{\text { LOAD }}$ or $\overline{R E S E T}$ INTACK will remain valid (high) until the SBP9989 leaves a hold state ( $\overline{\text { HOLD }}$ or XIPP released) or until the signal requesting interrupt is released <br>
\hline
\end{tabular}


*When HOLDA is active, these terminals are high

| SIGNATURE | PIN $=$ | 1/0 | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\overline{\text { XIPP }}$ | 58 | IN | EXTENDED INSTRUCTION PROCESSOR PRESENT When activated (low) by an external device (an extended instruction processor, XIP) upon detection of the acquisition of an SBP9989 undefined op code $\overline{X I P P}$ andicates the XIP will execute the undefined instruction Recognition of $\overline{X I P P}$ will cause the SBP9989 to allow its memory bus signals to be pulled high, activate HOLDA and enter a hold state fie, suspend internal operation) after it has stored its WP, PC and ST in the workspace defined by the interrupt level 2 trap vector Upon recelpt of HOLDA, the XIP may then proceed to execute the undefined instruction During the instruction execution, the XiP may utilize the WP, PC and ST previously stored in memory by the SBP9989 Upon completion of its instruction execution, the XIP releases $\overline{X I P P}$ and allows the SBP9989 to resume bus control and restart instruction execution The SBP9989 will resume operation by reloading (from memory) its WP, PC and ST XIPP may also be used to initiate a trap to interrupt level 2 by going active during IAQ for any instruction This is useful for mplementing breah points or maintenance panels |
| $\overline{\text { LOAD }}$ | 4 | 1 N | LOAD When active (low), $\overline{L O A D}$ causes the SBPg989 to set MPEN high, issue INTACK, store old PC, WP, and ST, set Status Register Bits 715 low and execute a nonmaskable interrupt with unmapped memory addresses FFFC 16 and FFFE 16 contaning the assoctated trap vectors (WP and PC) The load sequence is mitiated after the instruction being executed is completed $\overline{L O A D}$ will also terminate an idie state if $\overline{\mathrm{LOAD}}$ is active at the end of a reset function, the $\overline{\mathrm{LOAD}}$ trap will occur after the reset function is completed if $\overline{\text { LOAD }}$ is activated during a hold state (caused by XIPP or $\overline{\mathrm{HOLD}}$ ), the SBP9989 wili activate INTACK to indicate a pending $\overline{\text { LOAD }}$ needs to be serviced During hold states $\overline{L O A D}$ will remain active untll the SBP9989 leaves the hold state and the above conditions are met LOAD may be used to implement bootstrap loaders Additionally, front panel routines may be implemented using CRU bits as front panel interface signals, and software control routines to direct the panel operations |
| RESET | 6 | 1 N | RESET When active (low logic level), $\overline{\operatorname{RESET}}$ causes the SBP9989 to reset itself, and inhibit $\overline{W E}$ and CRUCLK When $\overline{\text { RESET }}$ is released, the SBP9989 goes through a level zero interrupt sequence by causing MPEN to go to high, issuing INTACK, storing old PC, WP and ST, setting all status register bits low, acquiring the WP and PC trap vectors from memory locatuons $0000_{16}$ and $000 \%_{16}$, and then fetching the first instruction of the reset program environment if $\overline{\mathrm{LOAD}}$ is not active The SBP9989 continuously samples $\overline{\text { RESET }}$ on low-to high clock transitions RESET must be active for one low-to-high transition of the clock and satisfy the hold time requirements of this stgnal |

## ARCHITECTURE AND TIMING

The memory word is 16 -bits long as shown in Figure 1 Words are assigned even-numbered addresses in memor Each memory word contains two bytes of 8 bits each The instruction set of the SBP9989 allows both word and byt. operations Byte instructions may address etther byte as necessary Byte instructions that address a Workspace Register operate on the most significant byte (even address) of the Workspace Register and leave the least significant byte (odd address) unchanged Since the workspace is also addressable as a memory address, the least significant byte may be addressed if desired

The SBP9989 memory map is shown in Figure 2 The first 32 words are used for interrupt trap vectors and the next contiguous block of 32 memory words is used by the XOP (Extended Operation) instruction for trap vectors The last two unmapped memory words (FFFC 16 and FFFE $_{16}$ ) are used for the trap vector of the foad signal The remaining memory is then avallable for programs, data, and Workspace Registers


FIGURE 1 - WORD AND BYTE FORMATS

## FUNCTIONAL DESCRIPTION

## Block Diagram

The block diagram is shown on page 10 A flow chart, representative of functional operation, is shown on page 9 Addresses are supplied to the Address Bus (AO-A14) by the Memory Address Register (MA) Instructions read from memory are loaded into the Instruction Register (IR) via the Data Bus (D0-D15)

Bit-oriented input/output operations are provided by the Communication Register Unit (CRU) interface whereby 1 to 16 bits may be transferred by a single instruction

## Arithmetic Logic Unit (ALU)

The arithmetic logic unit (ALU) is the computational component of the SBP9989 it performs all arithmetic and logic functions required to execute instructions The functions include addition, subtraction AND, OR, exclusive OR, and complement

The ALU is arranged in two 8-bit halves to accommodate byte operations Each half of the ALU operates on one byte of the operand During word operand operations, both halves of the ALU furiction in conjunction with each other However, during byte operand processing, the least significant half of the $4 L J$ operates in a passive mode, performins no operation on the data that it handies The most significant half of tre tu performs all operations on byte operands so tha, the status circuitry used in word operations is also used in bite operations


FIGURE 2 - MAP OF THE MEMORY ARRANGEMENT

## Internal Registers

The following three internal registers are accessible to the user (programmer).
a. Program Counter (PC)
b. Status Register (ST)
c. Workspace Pointer (WP)

Other internal registers which are utilized during instruction acquisition or execution are maccessible to the user.

## Program Counter (PC)

The program counter is a 15 -bit register (left justified with the LSB hardwired to 0 ) that contains the word address of the instruction currently executing. The SBP9989 increments this address to fetch the next instruction from memory

If the current instruction in the microprocessor alters the contents of the PC , then a program branch occurs to the location specified by the altered contents of PC. All context instructions affect the contents of the PC.

## Status Register (ST)

The status register is a fully implemented 16-bit register that reports the results of program comparisons, indicates program status conditions, supplies the arithmetic overflow enable and interrupt mask level to the interrupt priority circuits, and provides the external bit for memory expansion to 64 K words and beyond. Each bit position in the register signifies a particular function or condition that exists in the SBP9989 as illustrated in Figure 3 Some instructions use the status register to check for a prerequisite condition, others affect the values of the bits in the register, and others load the entire status register with a new set of parameters. The description of the instruction set later in this document details the effect of each instruction on the status register

*These bits are functionally uncommitted and are available to the user

## FIGURE 3 - STATUS REGISTER BIT ASSIGNMENTS

## Workspace

The SBP9989 uses blocks of memory words, called workspaces, for instruction operand manipulation (instead of internal hardware registers). A workspace occupies 16 contiguous memory words in any part of memory. The individual workspace registers may contain data or addresses, and function as operand registers, accumulators, address registers, or index registers Some workspace registers take on special significance during execution of certain instructions Figure 4 illustrates the workspace map A user-defined number of workspaces may exist in memory which provides a high degree of program flexibility

## Workspace Pointer (WP)

To locate the workspace in memory, one hardware register called the Workspace Pointer (WP) is used The Workspace Pointer is a 15 -bit register (left justified with the LSB hardwired to 0 ) that contains the memory address of the first word in the workspace The SBP9989 can then access any register in the workspace by adding two times the register number to the contents of the Workspace Pointer and initiating a memory request for that word Figure 5 illustrates the relationship between the Workspace Pointer and its corresponding workspace in memory.

## Context Switching

The workspace concept is particularly valuable during operations that require a context switch, which is a change from one program environment to another or to a subroutine as in the case of an interrupt Such an operation using a conventional mult-register arrangement requires that at least part of the contents of the register file be stored and relocated using a memory cycle to store or fetch each word This operation is accomplished by changing the Workspace Pointer A complete context switch requires only three store cycles and three fetch cycles, exchanging the program counter, status register and Workspace Pointer After the switch, the Workspare Pointer contains the starting address of a new 16 -word workspace in memory for use in the new routine A corress; igtime saving occurs when the original context is restored Instructions that result in a context switch inc' die rame and load workspace pointer (BLWP), return from subroutine (RTWP), and extended operation (XOP) iristre in Device interrupts, the arithmetic overflow interrupt, illegal opcode detection trap, $\overline{R E S E T}$, and $\overline{\text { LOAD }}$ alsc $\pm$ a context switch by forcing a trap to a service subroutine.

note the wp register contains the address of workspace register zero
figure 4 - WORK SPACE MAP


FIGURE 5 - WORKSPACE POINTER AND REGISTERS

In the case of a memory write cycle $\overline{W E}$ becomes active (logrc level low) with the first high to tow transition of the clock after $\overline{M E N E N}$ becomes active DBIN remains inactive (low) At the end of a memory write cycle $\overline{W E}$ and $\overline{M E M E N}$ ber ome inar tive ( $\overline{\mathrm{MEMEN}}$ on the low to high transition of clock $\overline{\mathrm{WE}}$ on the prereding high to low transition of clock)
During ether a memory read or a memory write operation READY may be used to extend the duration of the dssocidted memory cycle such that the speed of the memory system may be coordinated with the speed of the SBP9989 If READY is indctive (Ingic level low) during the first low to high transition of the clock atter MEMEN becomes artive the SBP9989 will enter a watt state suspending further progress of the memory cycle The first low to high transtion of the clock after READY becomes active terminates the watt state and allows normal ( ompletion of the memory cycle The cycle end signal ( $\overline{C Y C E N D}$ ) wilt be activated (logi level low) for one clock period during edch micromstruction (ycle (ie memory opetation non memory internal operation etc) $\overline{C Y C E N D}$ will be ar tivated on the low to high transition of the clock which mitiates the last clock period of a mocromstruction cycle and will be deacivated on the next low to high clock transition

## HOLD. DMA interface

The SBP9989 hold fac lities allow both the muroprocessor and external devices to share a common memory To gain memory bus control an external device requring direct memory access (DMA) sends a hold request ( $\overline{\mathrm{HOLD}}$ ) to the SBP9989 When the next ycle (memory or non memory) occurs the microprocessor enters a hold state and signals its surrender of the memory bus to the external device via a hold acknowledge (HOLDA) signal

Rereiving the hold acknowledgement the external device an proceed to utilize the common memory After its memory requrements have been satisfied the external device returns memory bus control by releasing $\overline{H O L D}$
When HOLD becomes active (logic level low) the SBP9989 enters a hold state at the begrnating of the next avalable (vele as shown in Figure 9 Upon entering a hold state HOLDA becomes dative (pulled to logic levet high) with the following signals pulled to a high logir level by individual puilup resistors tied to ear h resper live open collector output DBIN MEMEN IAQ MPEN WE CYCEND AO through A14 and DO through D15 When HOLD becomes inat tive the SBP9989 exits the hold state and requms memory bus control


FIGURE 9 MEMORY BUS TIMING FOR HOLD OPERATION

## :xtended Instruction Processor Interface

The extended instruction processor (XIP) interface provides for easy extension of the SBP9989 arithmetic logic processing functions by facilitating the addition of external hardware instruction processors while also permitting the usage of software interpretive implementations of extended instructions The XIP interface provides user transparency regardless of the method of implementation (ie hardware or software) potentially eliminating software overhead it allows true software transportability so that programs generated for systems based on the SBP9989 employing XIP s and those without XIP s can be identical

The XIP interface utilizes the SBP9989 memory bus with direct memory access (DMA) capability and the extended instruction processor present ( $\overline{\mathrm{XIPP}}$ ) signal as shown in Figure 10 The XIP interface requires the XIP to gain control of the SBP9989 memory bus during execution of any extended instructions encountered in the device program instruction stream The extended instructions are assigned (by the user) operation codes (op codes) which are the illegal (undefined) operation codes NOP s (ILLOP s)


FIGURE 10 - EXTENDED-INSTRUCTION INTERFACE PROCESSOR

The sequence that characterizes a typical extended instruction execution is shown in Figures 11 and 12 As illustrated the SBP9989 fetches the instruction that contains the op code assigned to an extended instruction The XIP detects the occurrence of the instruction fetch operation (IAQ active) and latches the instruction op-code data present on the memory data bus The XIP decodes the latched op-code as one of its instructions and asserts XIPP to the SBP9989 (non-extended instruction op codes would be ignored by the XIP) Recognition of the illegal op-code causes the SBP9989 to execute a program trap and store its context (ie WP PC and ST) in memory Storage will be in registers 1314 and 15 of the workspace defined by the WP value contained in the SBP9989 Level 2 interrupt vector locations If $\bar{X}$ IPP is aiso active (logic level low) the SBP9989 allows its memory bus signals to be pulled to a logic level high issues HOLDA (Hold Acknowledge) and suspends internal operation Having received HOLDA the XIP assumes control of the memory bus and proceeds with execution of the extended instruction(s) During its instruction execution the XIP may access the PC WP and ST values (previously stored in memory), via the interrupt Level 2 workspace address as required to derive instruction operands and indicate execution results (status) After completing instruction execution the XIP releases XIPP Detecting the removal of XIPP causes the SBP9989 to remove HOLDA activate its memory bus drivers (ie resume bus control) restore its context (WP PC and ST) from memorv and continue instruction processing Where it resumes processing is determined by the PC value (updated by the XIP during execution) which it reacquires from memory after resuming control


NOTES A VALID UNDEFINED OP CODE DATA FROM MEMORY B INPUT MODE
FIGURE 11 - EXTENDED INSTRUCTION PROCESSOR INTERFACE TIMING (ILLOP DETECTION)


FIGURE 12 - EXTENDED-INSTRUCTION PROCESSOR INTERFACE TIMING (WP.PC, ST RELOAD)

The XIP can be implemented with chaining capability, 1 e, the ability to execute a sequence of extended instructions without returning control to the SBP9989 If an interrupt or LOAD occurs and the interrupt mask conditions are satısfied, the SBP9989 will activate INTACK (ınterrupt acknowledge) to indicate that an interrupt needs to be serviced Servicing of the interrupt will occur upon release of XIPP by the XIP and completion of the above context restore bus control resumption sequence

As shown in Figure 10, the XIP interface provides for other Direct Memory Access (DMA) devices or more than one XIP device However, it is the responsibility of the XIP device to receive, condition and transmit the requred interface signals (i e , $\overline{H O L D}$, HOLDA, and $\overline{\text { XIPP }}$ ) to satisfy additional DMA or XIP requirements

For configurations not containing external XIP hardware, the XIPP signal will not be activated Therefore the SBP9989 completes the context switch operations by loading PC data from the interrupt Level 2 trap vector Software starting at this PC location then executes the intended function(s)

## Multiprocessor Interlock

The Multiprocessor Interlock (MPILCK) signal permits the implementation of an indivisible test and set-semaphore mechanism for use in multiprocessor applications The SBP9989 activates the MPILCK signal (logic level high ) during the execution of the Absolute Value (ABS) instruction as shown in Figure 13 MPILCK is activated on the low-to-high clock transition, inttiates the first ABS operand memory access and remains active untul the completion of the ABS instruction (ie occurrence of next |AO or servicing of an interrupt, $\overline{\text { LOAD }}$ or $\overline{\operatorname{AESET}}$ ) $\overline{H O L D}$ is sampled during this time, so MPILCK can be used to control the assertion of $\overline{H O L} \bar{D}$


FIGURE $13 a$ - MULTIPROCESSOR INTERLOCK TIMING (NEGATIVE-OPERAND)


FIGURE 13b - MULTIPROCESSOR INTERLOCK TIMING (POSITIVE-OPERAND)

## INTERRUPTS

The SBP9989 employs 16 interrupt levels with the highest priority Level 0 and lowest priofity Level 15 Level 0 is reserved for the $\overline{\operatorname{RE}} \overline{S E T}$ function Level 2 is reserved at the user's option for the arithmetic overflow interrupt and/or an Illegal op-code trap Interrupt Levels 1 through 15 may be used for external device interrupts

External device interrupts are input via the interrupt request (INTREO) signal line and the four interrupt code lines (ICO IC3) Figure 14 shows the timing for the sampling of these inputs and their effect on SBP9989 operation Activation of the INTREO input causes a comparison with the interrupt code (ICO-IC3) with the interrupt mask contained in status registerbits ST 12 through ST15 When the level of the pending interrupt is less than or equal to the enabling mask level (higher or equal priority interrupt), the SBP9989 recognizes the interrupt and initiates a context switch following completion of the currently executing instruction The new context (WP and PC) is fetched from the interrupt vector locations and the SBP9989 sets MPEN to one, activates the INTACK (interrupt acknowledge) signal line Then the previous context (WP, PC and ST) is stored in workspace registers 13,14 and 15 , respectively, of the new workspace Bits 7 through 11 of the status register are forced to zero and sets the interrupt mask to a value that is one less than the level of the interrupt being serviced, except for Level 0 interrupt, which loads zero into the mask This allows only interrupts of higher priority to interrupt a service routine The SBP9989 also inhibits interrupts until the first instruction of the device service routine has been executed All interrupt requests should remain active until recognized in the device service routine The individual service routines must reset the interrupt requests before the routine is completed


NOTES A NEXTIAQIF INTERRUPT NOT SERVICED
B INTREQ AND ICOIC3 CHANGED BY INTERRUPT SERVICE ROUTING
C THIS DIAGRAM ASSUYES VALID IC IS OF HIGHER PRIORITY THAN CODE IN STATUS REGISTER

FIGURE 14 - INTERRUPT TIMING

If a higher-priority occurs, a second context switch occurs to service the higher priority interrupt When that routine is complete, a return instruction (RTWP) restores the routine parameters to complete processing of the lower prionity interrupt All interrupt subroutines should terminate with the return instruction to restore original program parameters The interrupt vector locations, device assignments enabling mask value, and the interrupt codes are shown in Table 1
During a SBP9989 hold state resulting from the activation of $\overline{H O L D}$ or XIPP, the SBP9989 will continue to sample the tnterrupt code lines Upon activation of INTREQ if the code is less than or equal to the device interrupt mask level the SBP9989 will activate the INTACK signal to indicate a pending interrupt needs servicing The INTACK signal will then remain active until $\overline{\mathrm{HOLD}}$ or $\overline{\mathrm{XIPP}}$ is released

TABLE 1 - INTERRUPT LEVEL DATA


NOTES 1 Level 0 cannot be disabied
2 Arithmetic overtlow interrupt is generated internal to the device and is enabled disabled by bit 10 of the starus register
$3 \quad$ llegal op code trap is generated internal to the device and it cannot be disabled by the interrupt mask
4 XIPP (pin 58) is mactive at logic leve! high

## Interrupt Level 0 - RESET

Interrupt Level 0 is reserved for the $\overline{\text { RESET input to the SBP9989 When asserted (logic level low), } \overline{\operatorname{RESET}} \text { causes the }}$ SBP9989 to reset itself and inhibit $\overline{W E}$ and CRUCLK
When RESET is released, a Level 0 interrupt sequence is initiated acquiring the WP and PC trap vectors from memory locations $0000_{16}$ and 000216 . INTACK is activated, all status register bits are set low, and the first instruction of the reset program environment is fetched. If $\overline{L O A D}$ is active, the $\overline{\operatorname{LOAD}}$ trap occurs after the $\overline{\mathrm{RESET}}$ function is completed The SBP9989 contınuously samples $\overline{\operatorname{RESET}}$ on low-to-hıgh clock transitions as shown in Figure 15. To be recognized, $\overline{R E S E T}$ must be active for one low-to-high transition of clock and must satisfy the setup and hoid time requirements

## Interrupt Level 2

Interrupt Level 2 has two additional capabilities associated with its usage. Arithmetic overflow conditions, indicated by status register bit $4(S T 4)=1$, can cause a Level 2 interrupt to occur at the end of the instruction which generated the overflow condition. Servicing of this overfiow interrupt can be enabled/disabled by status register bit 10 (ST10), the Arithmetic Overflow Enable Bit (i.e., ST10 = 1 enables overflow interrupt, ST10 $=0$ disables overfiow interrupt). The overfiow interrupt can also be inhibited by the interrupt mask (ST12-ST15) or overridden by a pending Level 0 or Level 1 interrupt. If servicing the overflow interrupt is overridden by a higher priority (Level 0 or 1) interrupt, the overflow condition will be retained in the contents of the status register, which are saved by the higher-priority-interrupt context switch Returning from the higher-priority-interrupt subroutine via an RTWP instruction causes the overflow condition to be reloaded into status register bit 4 (ST4) and the overflow interrupt to occur upon completion of the RTWP instruction. Servicing of a Level 2 arithmetic overflow interrupt forces the interrupt mask to 00012 The arithmetic overflow interrupt service routine must reset ST4 to zero before the routine is complete


CONTEXT SWITCH
122 CLOCK CYCLES

NOTES A DASHED LINES INDICATE SIGNAL WAVEFORMS IF RESET HAD NOT OCCURRED
B CASE SHOWN ASSUMES RESET IS DETECTED DURING MEMORY OPERATIONं
C SYNCHRONIZE RESET WITH IAQ ON T1 TO PREVENT LOSS OF INSTRUCTION IN PROGRESS
D FESET MAY OCCUR ON ANY LOW TO HIGH CLOCK EDGE FOLLOWING DEACTIVATION OF RESET.
E CONTEXT SWITCH WILL START ON LOW TO HIGH CLOCK EDGE FOLLOWING DEACTIVATION OF RESET

FIGURE 15 - RESET TIMING

## Undefined Op-code Trap

The acquisition and execution of Hlegal SBP9989 (undefined) op codes cause a trap operation to orcul using trp information stored in the Level 2 vectors The op codes which cause the trap are 0000007 F 00 AO 017 F 0320033 F 0780-07FF OC00 OFFF As described earlier if the XIPP signal is actuated during the undefinen instrution the SBP9989 will suspend operation and the instruction will be executed by the XIP However if the XIPP signal rema ns inactive the undefined op-code will cause a trap and a context swich will occur The occurrence of the trak is non maskable ( e e not controlled by the interrupt mask valuel and the trap will override ary levelinterrupt interrupts are inhibited until the first instruction of the trap subroutine is executed The occurrence of the undefmed op code trap does not change the interrupt mask

## Communication Register Unit (CRU) Interface

The Communications Register Unt (CRU) is a direct command driven bit onentedl O nterface The CRU Mavdrectly address, in bit-fields of one to sixteen bits up to 4096 peripheral input bits and up to 4096 peripheral output b ts The SBP9989 executes three single-bit and two multiple bit CRU instructions The single bit instructions includt test bit (TB), set bit to one (SBO) and set bit to zero (SBZ) the multiple bit instructions include load CRU (LDCR) ard store CRL (STCR)

As shown in Figure 16 the SBP9989 utilizes three dedicated O signals CRUIN CRUOUT CRUCLK the least significant twelve bits of the address bus DBIN READY and WAIT to support the CRU interface CRU interface timing is shown in Figures 17 and 18

To transfer a data bit to a CRU device the SBP9989 outputs the corresponding CRU bit address on address bus bits A3 through A14, a CRUCLK pulse and the respective data bit on CRUOUT (Address bus bits AO through A2 are set to zero during CRU transfers) This process is repeated until transfer of the enture field of data bits specifed by the CRU instruction has been accomplished To transfer a data bit from a CRU device the SBP9989 outputs the corresponding CRU bit address on address bits A3 through A14 and receives the respective riata ont on CRUN No CRUCLK pulses occur during a CRU input operation

During all CRU input and output operations the SBP9989 will activate the DBIN output (logic level high) and place the 16-bit Data Bus in the input mode Activation of DBIN will allow users to detect the occurrence of a CRU cycle and facilitate cycle stealing by a DMA device since all uses of the DATA and ADDRESS busses will be indicated by the activation of DBIN or MEMEN


FIGURE 16 - CRU INTERFACE SUPPORT


FIGURE 17 - CRU TIMING (INPUT OPERATION)


FIGURE 18 - CRU TIMING (OUTPUT OPERATION)

During either a CRU input or output operation, READY may be used to extend the duration of the associated CRU operation such that the speed of the CRU device may be coordinated with the speed of the SBP9989 If READY is nactive (logic level low) during the first low-to-high transition of clock after the initiation of the CRU operation the SBP9989 will enter a watt state (ie, WAIT becomes active) suspending further progress of the CRU cycle The first low to high transition of clock after READY becomes active terminates the want state and allows normal completion of the CRU operation

## Single Bit CRU Operation

The SBP9989 performs three single-bit CRU functions Test bit (TB) set bit to one (SBO) and set bit to zero (SBZ) To identify the bit to be operated upon, a CRU bit address is developed and placed on the address bus, A3 to A14 For the two output operations (SBO and SBZ), the device also activates DBIN, generates a CRUCLK pulse, indicating an output operation to the CRU device, and placed bit 7 of the instruction word on the CRUOUT hine to accomplish the specified operation ( Btt 7 is a one for SBO and a zero for SBZ) A test bit (TB) instruction transfers ne addressed CRU bit from the CRUJIN input tine to bit 2 of the status register (ST12)

The SBP9989 develops a CRU-bit address for the single-bit operations from the CRU base address contaned in work-space register 12 and the signed displacement count contained in bits 8 through 15 of the instruction The displacement allows two's complement addressing from base minus 128 bits through base plus 127 bits the base address from workspace register 12 is added to the signed displacement specified in the instruction and the result is loaded onto the address bus Figure 19 illustrates the development of a single-bit CRU address


DONT CARE


FIGURE 19 -- BIT ASSIGNMENT FOR SINGLE-BIT CRU ADDRESS

## Multiple Bit CRU Operations

The SBP9989 performs two multiple-bit CRU operations store commumication register (STCR) and load communications register (LDCR). Both operations perform a data transfer from the CRU-to-memory or from memory-to-CRU as Illustrated in Figure 20 Although the figure ilfustrates a full 16 -bit transfer operation, any number of bits from 1 through 16 may be involved The LDCR instruction fetches a word from memory and right shifts it to transfer it serially to CRU output bits. The LDCR involves eight or fewer bits, those bits come from the right-justified field within the addressed byte of the memory word. If the LDCR invoives nine or more bits, those bits come from the right-justified field within the whole memory word. When transferred to the CRU interface, each successive bit receives an address that is sequentially greater than the address for the previous bit. This addressing mechanism results in an order reversal of the bits, that is, bit 15 of the memory word (or bit 7) becomes the lowest addressed bit in the CRU and bit 0 becomes the highest addressed bit in the CRU field

A STCR instruction transfers data from the CRU to memory. If the operation involves a byte or less transfer, the transferred data will be stored right-justified in the memory byte with leading bits set to zero If the operation involves from nine to sixteen bits, the transferred data is stored right-fustified in the memory word with leading bits set to zero When the input from the CRU device is complete, the first bit from the CRU is the least-significant bit position in the memory word or byte


FIGURE 20 - BIT TRANSFER WITH CRU INTERFACE

## xternal Instructions

The SBP9989 has five external instructions that allow user-defined external functions to be initiated under program control These instructions are CKON, CKOF, RSET, IDLE, and LREX. These mnemonics, except for IDLE, relate to functions implemented in the 990 minicomputer and do not restrict use of the instructions to initiate various userdefined functions IDLE causes the device to enter the ide state and remain until an interrupt, $\overline{\operatorname{RESET}}$, or $\overline{\mathrm{LOAD}}$ occurs When any of these five instructions are executed, a unique 3 -bit code appears on the most-significant 3 bits of the address bus ( $A 0$ through A2) along with activation of DBIN and the occurrence of a CRUCLK pulse When in an idle state the codes on the address bus and CRUCLK pulse occur repeatedly until the idle state is terminated The 3-bit codes are shown in Table 2

## DAD Function

The $\overline{\text { LOAD }}$ signal allows cold start("bootstrap") ROM loaders and front panel functions to be implemented When active, LOAD causes a trap immediately following the instruction being executed Unmapped memory locations FFFC16 and FFFE 16 are used to obtain the trap vector (WP and PC respectively) The interrupt ac'snowledge (INTACK) output is activated during the fetch of the new WP value. The old PC, WP and ST are loaded into the new workspace, status register bits ST7-ST15 are set to 0 (logic levellow), and $\overline{M P E N}$ is set to one Then, program execution resumes using the new PC and WP During a hold state (caused by activation of $\overline{H O L D}$ or $\overline{\mathrm{XIPP}}$ ), the SBP9989 will continue to sample the
 INTACK will then remain active until $\overline{\mathrm{HOLD}}$ or $\overline{\mathrm{XIPP}}$ is released

During non-hold states, $\overline{\text { LOAD }}$ shall remain active for one instruction period/i e, $\overline{L O A D}$ should go acive during IAQ and remain active until the next IAO) or until the external device detects the activation of INTACK concurrent with a memory read operation at location FFFC16 During hold states, $\overline{\mathrm{LOAD}}$ shall remain active until the external device detects the activation of INTACK concurrent with a memory read operation at location FFFC16

TABLE 2 - EXTERNALINSTRUCTION FUNCTION TABLE

| EXTERNAL INSTRUCTION | AO | A1 | A2 |
| :---: | :---: | :---: | :---: |
| LREX | $H$ | $H$ | $H$ |
| CKOF | $H$ | $H$ | $L$ |
| CKON | $H$ | $L$ | $H$ |
| IDSET | $L$ | $H$ | $H$ |

## STANDARD INSTRUCTION SET

Each SBP9989 instruction performs one of the following operations
1 Arithmetıc, logical, comparison, or manipulation operation on data
2. Loading or storage of internal registers (program counter, workspace pointer, or status)

3 Data transfer between memory and external devices via the CRU
4 Control functions

## TERMS AND DEFINITIONS

The terms used in describing the instructions and status bits of the SBP9989 are defined below.
terms and definitions

| TERM | definition |
| :---: | :---: |
| B | Byte Indicator $11=$ byte, $0=$ word) |
| C | Bit Count |
| D | Destination address register |
| DA | Destination address |
| 10 P | Immediate operand |
| LSB( $n$ ) | Least significant (right-most) bit of $n$ |
| MSB( n ) | Mast significant (left most) bit of $n$ |
| PC | Program Counter |
| Result | Result of operation performed by instruction |
| S | Source address register |
| SA | Source address |
| ST | Status register |
| STn | Bitn of status register |
| $T_{0}$ | Destination address-mode control |
| TS | Source address-mode control |
| WR | Workspace register |
| WRn | Workspace register $n$ |
| WR(0,1) | Concatenation of WR0 and WR 1 to form a 32 bit register |
| $a \rightarrow b$ | $a$ is transferred to $b$ |
| \|n| | Absolute value of $n$ |
| + | Arithmetic addition |
| - | Arithmetic subtraction |
| AND | Logical AND |
| OR | Logical OR |
| ¢ | Logical exclusive OR |
| $\bar{n}$ | Logical complement of $n$ |
| $\times$ | Arithmetic muitiplication |

## ADDRESSING MODES

The SBP9989 instructions contain a variety of avalable modes for addressing random memory data le g, program parameters and flags), or formatted memory data (character strings, data lists, etc) These addressing modes are
o Workspace Register Addressing

- Workspace Register Indirect Addressing
o Workspace Register Indirect Auto Increment Addressing
- Symbolic (Direct) Addressing
- Indexed Addressing
- Immediate Addressing
- Program Counter Relative Addressing
- CRU Relative Addressing

The following figures graphically describe the derivation of the effective address for each addressing mode The applicability of addressing modes to particular instructions is described next along with the description of the operations performed by the instruction The symbols following the names of the address ny modes ( $R,{ }^{*} R$, * $R+$, @LABEL, or @TABLE(R)) are general forms used by 9900 assemblers to select the addressing modes for Register $R$

## Workspace Regıster Addressing . . R

The workspace register addressing mode is specified by setting the 2 bit $T$ field ( $T_{S}$ or $T_{D}$ ) of the instruct on worc) equal to 00 Workspace register R contams the operand


## Workspace Register Indırect Addressing *R

The workspace register indirect addressing mode s specified by setting the 2 bit $T$ field (TS or TD' in the instruc: $c$, word equal to 01 Workspace register $R$ contans the address of the operand


Workspace Register Indirect Auto-Increment Addressing . . . *R+
The workspace register indirect auto increment addressing mode is specified by setting the 2 bit $T$ field (TS or TD' in the instruction word equal to 11 Workspace register $R$ contains the address of the operand After the address of the operand is acquired, the contents of workspace register $\mathbf{R}$ is incremented


Symbolic (Direct) Addressing . . . @LABEL
The symbolic addressing mode is specified by setting the 2-bit $T$ field ( $T_{S}$ or $T_{D}$ ) in the instruction word equal to 10 and setting the corresponding $S$ or $D$ field equal to 0 . The word following the instruction contains the address of the operand.


## Indexed Addressing . . . @TABLE(R)

The indexed addressing mode is specified by setting the 2 -bit $T$ field ( $T_{S}$ or $T_{D}$ ) of the instruction word equal to 10 . The value in the corresponding $S$ or $D$ feld is the register which contans the index value Register 0 may not be used for indexed addressing.

The word following the instruction contains the base address. Workspace register $R$ contains the index value. The sum of the base address and the index value results in the effective address of the operand.



## Program Counter Relative Addressing

The 8-bit signed displacement in the right byte (bits 8 -15) of the instruction is multipited by 2 and added to the updated contents of the program counter The result is placed in the PC


## CRU Relative Addressing

The 8 -bit signed displacement in the right byte of the instruction is added to the CRU base address (bits 314 of the workspace register 12) The result is the CRU address of the selected CRU bit


## STATUS REGISTER MANIPULATION

Various SBP9989 machine instructions affect the status register The figure below shows the status register bit assignments and the following table lists the effects of the instructions on each status bit.

*These bits are functionally uncommitted and are available to the user.

TABLE 3 - STATUS REGISTER BIT DEFINITIONS

| BIT | NAME | INSTRUCTION | CONDITION TO SET BIT TO 1 |
| :---: | :---: | :---: | :---: |
| STO | Logical <br> Greater <br> Than | C. CB <br> Cl <br> ABS, LDCR <br> RTWP <br> LST <br> All others | ```If MSB \((S A)=1\) and \(M S B(D A)=0\), or if MSB(SA) \(=\mathrm{MSB}(\mathrm{DA})\) and MSB OF [(DA) - \((S A)]=1\). if \(M S B(W R)=1\) and \(M S B\) of \(1 O P=0\), or if \(M S B(W R)=M S B\) of \(1 O P\) and \(M S B\) of \([I O P-(W R)]=1\). If \((S A) \neq 0\). If \(\mathrm{Bit}(0)\) of WR 15 is 1 . If Bit ( 0 ) of selected WR is 1 . If result \(=0\).``` |
| ST1 | Arıthmetic <br> Greater <br> Than | C. $C B$ <br> Cl <br> ABS, LDCR <br> RTWP <br> L.ST <br> All others | ```If \(\mathrm{MSB}(\mathrm{SA})=0\) and \(\mathrm{MSB}(D A)=1\), or if \(M S B(S A)=M S B(D A)\) and MSB of \([(D A)-(S A)]=1\). If \(M S B(W R)=0\) and \(M S B\) of \(1 O P=1\), or if \(M S B(W R)=M S B\) of \(1 O P\) and \(M S B\) of \([1 O P-(W R)]=1\). If \(\operatorname{MSB}(S A)=0\) and \((S A) \neq 0\). If \(B\) it (1) of WR 15 is 1. If Bit (1) of selected WR is 1 . If MSB of result \(=0\) and result \(\neq 0\)``` |
| ST2 | Equal | C. CB <br> Cl <br> COC <br> cZC <br> TB <br> ABS, LDCR <br> RTWP <br> LST <br> All others | $\begin{aligned} & \text { If }(S A)=(D A) . \\ & \text { If }(W R)=1 O P . \\ & \text { If }(S A) \text { and } \overline{(D A)}=0 . \\ & \text { If }(S A) \text { and }(D A)=0 . \\ & \text { If } C R U I N=1 . \\ & \text { If }(S A)=0 . \\ & \text { If } B \text { it }(2) \text { of WR15 is } 1 . \\ & \text { If } B \text { it }(2) \text { of seiected } W R \text { is } 1 \\ & \text { If result }=0 . \end{aligned}$ |

STATUS REGISTER BIT DEFINITIONS (Continued)

| BIT | NAME | INSTRUCTION | CONDITION TO SET BIT TO 1 |
| :---: | :---: | :---: | :---: |
| ST3 | CARRY | ```A AB,ABS,AI, DEC, DECT, INC INCT NEG,S,SB SRA, SLA, SRL SRC RTWP LST``` | If CARRY OUT-1 <br> If last bit shifted out - 1 <br> If Bit \{3) of WR15 is 1. <br> If Bit (3) of selected WR is 1 |
| ST4 | OVERFLOW | $\mathrm{A}, \mathrm{AB}$ <br> AI <br> $S, S B$ <br> DEC, DECT <br> INC, INCT <br> SLA <br> DIV <br> DIVS <br> ABS, NEG <br> RTWP <br> LST | ```If MSB(SA) = MSB(DA) and MSB uf result = MSB (DA) If MSB(WR)= MSB of IOP and MSB of result }\not=\textrm{MSB}(WR If MSB(SA) }\not=\mathrm{ MSB(DA) and MSB of result }\not=\mathrm{ MSB(DA). If MSB(SA) = 1 and MSB of result = 0 If MSB(SA) = 0 and MSB of result = 1. If MSB changes during shift If MSB(SA) = 0 and MSB(DA) = 1 or if MSB(SA) = MSB(DA) and MSB of [(DA)-(SA)] = 0. If (SA) = 0000 or if MSB(SA) fMSB(WRO) and \|(215+1)\times(SA)|<WR(0,1) If (SA) = 8000 If Bit (4) of WP:5 is 1. If Bit (4) of selected WR is ?.``` |
| ST5 | PARITY, . | $\begin{aligned} & \text { CB, MOVB } \\ & \text { LDCR } \\ & \text { AB, SB, SOCB, SZCB } \\ & \text { RTWP } \\ & \text { LST } \\ & \text { STCR } \end{aligned}$ | If (SA) had odd number of 1 's. <br> If $1 \leqslant C \leqslant 8$ and (SA) has odd number of 1 s . <br> If result has odd number of 1 's. <br> If Bit (5) of WR15 is 1. <br> if Bit (5) of selected WR is 1 <br> If $1 \leqslant C \leqslant 8$ and result has odd number of 1 s . |
| ST6 | XOP | XOP <br> RTWP <br> LST | If XOP instruction is executed If Bit (6) of WR 15 is 1. If Bit $\{6$ of sefected WR is 1. |
| ST7, ST9 or ST11 | User defined | RTWP LST | If corresponding bit of WR15 is 1 or If corresponding bit of selected WR is 1. |
| ST8 | MEMORY MAP | RTWP LST | If Bit (8) of WR15 is 1. <br> If Bit (8) of selected WR is 1 . |
| ST 10 | ARITHMETIC OVERFLOW enable | RTWP LST | If Bit (10) of WR15 is 1. <br> If $\mathrm{Bit}_{\text {(10) }}$ ) of selected WR is 1. |
| ST12 <br> THRU <br> ST15 | INTERRUPT MASK | LIMI <br> RTWP <br> LST | If corresponding bit of IOP is 1. <br> If corresponding bit of WR15 is 1. <br> If corresponding bit of selected WR is 1 . |

NOTE Interrupt $\overline{\text { LOAD }, ~ X O P s, ~ I L L O P s, ~ a n d ~} \overline{\text { RESET }}$ operations sets Bits ( 711 ) to 0

## INSTRUCTIONS

Dual-Operand Instructions with Multiple Addressing for Source and Destmation Operands

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OP CODE |  |  | B | TD |  |  | D |  |  | TS |  | S |  |  |  |

If $\mathrm{B}=1$, the operands are bytes and the operand addresses are byte addresses. If $\mathrm{B}=0$, the operands are words and the operand addresses are word addresses The addressing mode for each operand is determined by the T field of that operand.

| TS or TD | S or D | ADDRESSING MODE | NOTES |
| :--- | :--- | :--- | :--- |
| 00 | $0 \quad 15$ | Workspace register | 1 |
| 01 | $0-15$ | Workspace register indirect |  |
| 10 | 0 | Symbolic | 4 |
| 10 | 1.15 | indexed | 2,4 |
| 11 | 0.15 | Workspace register <br> indirect auto-increment | 3 |

NOTES 1 When a workspace register is the operand of a byte instruction (Bit (3) = 1), the most significant \|eft) byte (Bits (0 7)) is the operand and the least significant (right) byte (Bits (8 15)) remains unchanged
2. Workspace register 0 may not be used for indexing

3 The workspace register is incremented by 1 for byte instructions (Bit (3) $=1$ ) and is incremented by 2 for word instructions ( $\mathrm{Bit}(3)=0$ )
4 When $T_{S}$ and $T_{D}=10$, two words are required in addition to the instruction word The first word is the source operand base address and the second word is the destmation operand base address

| MNEMONIC | MEANING | OP CODE | B | RESULT COMPARED TO 0 | STATUS BITS AFFECTED | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A | Add | 101 | 0 | Yes | 04 | $(S A)+(D A) \rightarrow(D A)$ |
| $A B$ | Add bytes | 101 | 1 | Yes | 05 | $(S A)+(D A) \rightarrow(D A)$ |
| C | Compare | 100 | 0 | No | 0.2 | Compare (SA) to (DA) and set appropriate status bits |
| CB | Compare bytes | 100 | 1 | No | $0 \cdot 2,5$ | Compare (SA) to (DA) and set appropriate status bits |
| 5 | Subtract | 011 | 0 | Yes | 04 | $(\mathrm{DA})-(\mathrm{SA}) \rightarrow(\mathrm{DA})$ |
| SB | Subtract bytes | 011 | 1 | Yes | 0.5 | $(\mathrm{DA})-(S A) \rightarrow(\mathrm{DA})$ |
| SOC | Set ones corresponding | 111 | 0 | Yes | 0.2 | $(D A) O R(S A) \rightarrow(D A)$ |
| SOCB | Set ones corresponding bytes | 111 | 1 | Yes | 0-2,5 | $(\mathrm{DA}) \mathrm{OR}(\mathrm{SA}) \rightarrow(\mathrm{DA})$ |
| SZC | Set zeros corresponding | 010 | 0 | Yes | 0.2 | (DA) AND $(\underline{S A}) \rightarrow(\mathrm{DA})$ |
| SZCB | Set zeros corresponding bytes | 010 | 1 | Yes | $0 \quad 2,5$ | $(\mathrm{DA}) \mathrm{AND}(\mathrm{SA}) \rightarrow(\mathrm{DA})$ |
| MOV | Move | 110 | 0 | Yes | 0-2 | $(S A) \rightarrow(D A)$ |
| MOVB | Move bytes | 110 | 1 | Yes | 0-2,5 | $(S A)-(D A)$ |


| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  | OP CODE |  | D |  |  |  | TS |  | S |  |  |  |  |  |  |

The addressing mode for the source operand is determined by the TS field

| $\mathbf{T}_{\mathbf{S}}$ | $\mathbf{S}$ | ADDRESSING MODE | NOTES |
| :---: | :---: | :--- | :--- |
| 00 | $0-15$ | Workspace register |  |
| 01 | 015 | Workspace register indirect |  |
| 10 | 0 | Symbolic |  |
| 10 | 115 | Indexed | 1 |
| 11 | 015 | Workspace register indirect | 2 |
|  |  | auto increment |  |

NOTES 1 Workspace register 0 may not be used for indexing
2 The workspace register is incremented by 2

| MNEMONIC | MEANING | OP CODE | $\begin{gathered} \text { RESULT } \\ \text { COMPARED } \\ \text { TO } 0 \end{gathered}$ | status BITS AFFECTED | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\operatorname{coc}$ | Compare ones corresponding | 001000 | No | 2 | Test (D) to determine if 1 s are m each bit postuon where 1 s are in (SA) If so, set ST2 |
| czc | Compare zeros corresponding | 001001 | No | 2 | Test (D) to determine rt Os are in each bri position where 1 's are in (SA) if so, set ST2 |
| XOR | Exclusive OR | 001010 | Yes | $0 \cdot 2$ | (D) $\oplus(\mathrm{SA})-$ - (D) |
| MPY | Multiply | 001110 | No |  | Multiply unsigned (D) by unsigned (SA) and place unsigned 32 bit product in D (most significant) and $D+1$ (\}east significant) if WR15 is D, the next word in memory after WR15 will be used for the least significant half of the product |
| DIV | Divide | 001111 | No | 4 | If unsigned (SA) is less than or equal to unsigned (D), perform no operation and set ST4 Otherwise, divide unsigned (D) and ( $\mathrm{D}+1$ ) by unsigned (SA) Quotient - (D), remander $\rightarrow(0+1)$ If $D$ is WR 15, the next word in memory after WR15 will be used for the remander |



The addressing mode for the source operand is determined by the TS field.

| $\mathbf{T}_{\mathbf{S}}$ | $\mathbf{S}$ | ADDRESSING MODE | NOTES |
| :---: | :---: | :--- | :---: |
| 00 | 0.15 | Workspace register | 1 |
| 01 | 0.15 | Workspace register indirect | 1 |
| 10 | 0 | Symbolic | 1 |
| 10 | 1.15 | Indexed | 1,2 |
| 11 | 0.15 | Workspace register indirect | 1,3 |

NOTES 1 Workspace registers 0 and 1 contain operands used in the signed multiply and divide operations
2 Workspace register 0 may not be used for indexing
3 The workspace register is incremented by 2

| MNEMONIC | MEANING | OP CODE | $\qquad$ | $\begin{aligned} & \text { STATUS } \\ & \text { BITS } \\ & \text { AFFECTED } \end{aligned}$ | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| MPYS | Signed Multiply | 0000000111 | Yes | 02 | Multiply signed 2 's-complement integer in WRO by signed 2 's complement integer (SA) and place signed 32 -bit product in WRO (most significant) and WR1 (least significant) |
| DIVS | Signed Divide | 0000000110 | Yes | 0-2,4 | If $(S A)=0000$ or if <br> MSB (SA) $=$ MSB (WRO) and $\left\|2^{15} \times(S A)\right\| \leqslant\|W R(0,1)\|$ or if <br> MSB (SA) $\neq$ MSB (WRO) and $\left\|\left(2^{15}+1\right) \times(S A)\right\| \leqslant \mid$ WRO $(0,1) \mid$, set ST4 Otherwise, divide signed 2 's-complement integer in WRO and WRI by the signed 2 's complement integer (SA) and place the signed quotient in WRO and the signed remainder in WR1 The sign of the quotient is determined by algebraic rules The sign of the remainder is the same as the sign of the dividend |


| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  | OP CODE |  |  |  | $T_{S}$ |  |  | $S$ |  |  |  |  |  |  |  |

The TS and S fields provide multiple mode addiessinq capability for the source operand

*Onerand is compared to zero tor status bit

* II additional memory words for the execute instruction are tequared to define the operdnds of the mstuction located at SA these words will be accessed from PC and the PC will be updated accotingly The instruction actursithon siqnd (IAO) will not be the when the SBP9989 acresses the instuction at $S A$ Statis buts ate affected in the normal manner for the instruction execuled


The C freld specifies the number of bits to be transferred if $\mathrm{C}=0,16$ bits will be transferred The CRU base register (WR12, Bits 3 14) defines the starting CRU bit address The bits are transferred serially and the CRU address is moremented with each bit transfer, although the contents of WR12 are not affected TS and S provide multiple mode addressiny capability for the sounce operand If 8 or fewer bits are transferred ( $1=\mathrm{C}$ - 8 ), the source address is a byte detiress if 9 or more bits are transfered (C $0, \mathrm{C}=9$, the source address is a word address if the source is addressed in the workspace reqister indirect duto increment mode, the workspace register is incremented by $1 \leqslant C \leqslant 8$, and is ifi remented by 2 otherwise

| MNEMONIC | MEANING | OP CODE | COMPARED $\text { TO } 0$ | BITS <br> AFFECTED | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Lu) | Load communtadion iegister | 001100 | Yes | $025 *$ | Beginning with LSB of (SA), transfer the specifred number of bits from (SA) io the CRU |
| srch | Store communtation register | 001101 | Yes | 0 2, ${ }^{\text {\% }}$ | Begmning with L.SB of (SA), IIanster the specified number of this from the GRU to (SA) Load unfilled bit positions with 0 |

## CRII Smgle Bit Instructions

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OP CODE |  |  |  |  |  |  |  | SIGNED DISPLACEMENT |  |  |  |  |  |  |  |

CRU ielditive ddiessing is used to afiliess the selected CRU bit

| MNEMONIC | MEANING | OP CODE | STATUS <br> Birs <br> AFFECTED | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| Sthe | Sat bet torne | 00011101 |  | Set the seled ted ChU output bit to 1 |
| blic | Set hit torero | 00011110 |  | Set the selected CRU outpur the to 0 |
| 10 | lest bit | 00011111 | 2 | It the selected CRU mput bit 1 set $S T 2$ to 1 If the selected CRU mput bit 0 set $S 52$ to 0 |


| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | OP CODE |  |  |  |  |  |  | DISPLACEMENT |  |  |  |  |  |  |  |

Jump instructions cause the PC to be loaded with the value selected by PC relative addressing if the status register condition is met Otherwise, no operation occurs and the next instruction is executed since the PC points to the next instruction The displacement field in 2's-complement form is a word count to be added to PC Thus, the jump instruction has a range of -128 to 127 words from the memory word address following the jump instruction. No ST bits are affected by jump instructions

| MNEMONIC | MEANING | OP CODE | STATUS REGISTER CONDITION TO LOAD PC |
| :---: | :---: | :---: | :---: |
| JEQ | Jump equal | 00010011 | $S T 2=1$ |
| JGT | Jump greater than | 00010101 | ST $1=1$ |
| JH | Jump high | 00011011 | $S T 0=1$ and ST2 $=0$ |
| JHE | Jump high or equal | 00010100 | $\mathrm{STO}=1$ or ST2 $=1$ |
| JL | Jump low | 00011010 | $\mathrm{STO}=0$ and $\mathrm{ST} 2=0$ |
| JLE | Jump low or equal | 00010010 | STO $=0$ or ST2-1 |
| JLT | Jump less than | 00010001 | ST1 $=0$ and ST2 $=0$ |
| JMP | Jump unconditional | 00010000 | unconditional |
| JNC | Jump no carry | 00010111 | $\mathrm{ST} 3=0$ |
| JNE | Jump not equal | 00010110 | $\mathrm{ST} 2=0$ |
| JNO | Jump no overflow | 00011001 | ST4 $=0$ |
| JOC | Jump on carry | 00011000 | ST3 $=1$ |
| JOP | Jump odd parity | 00011100 | ST5 = 1 |

## Shift Instructions



If $C \neq 0$, Bits $12-15$ of WRO contain the shift count. If $C=0$ and Bits $12-15$ of WRO $=0$, the shift count is 16 .

| MNEMONIC | MEANING | OP CODE | ```RESULT COMPARED TO 0``` | STATUS BITS AFFECTED | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SLA | Shift left arithmetic | 00001010 | Yes | 0.4 | Shift (WR) left Fitt vacated bit positions with 0 |
| SRA | Shift right arithmetic | 00001000 | Yes | $0 \cdot 3$ | Shift (WR) right. Fill vacated bit positions with origenal MSB of (WR) |
| SRC | Shift right circular | 00001011 | Yes | 03 | Shift (WR) right Shift previous LSB into MSB |
| SRL | Shift right logical | 00001001 | Yes | 0-3 | Shift (WR) right. Fill vacated bit positions with 0 's |

## Immediate Register Instructions

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | OP CODE |  |  |  |  |  |  | 77 |  | WR |  |  |
| IOP |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |


| MNEMONIC | MEANING | OP CODE | RESULT <br> COMPARED <br> TO | STATUS <br> BITS <br> AFFECTED | DESCRIPTION |
| :--- | :---: | :---: | :---: | :---: | :---: |


| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | OP CODE |  |  |  |  |  |  |  |  |  | 17 |  | 2 |  | - |
|  | IOP |  |  |  |  |  |  |  |  |  |  |  |  |  |  |


| MNEMONIC | MEANING | OP CODE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| LWPI | Load workspace <br> pointer immediate | 00000010111 | 1 OP $\rightarrow$ (WP), no ST bits affected |
| LIMI | Load interrupt <br> mask immediate | 00000011000 | Bits (12 15) of 10P $\rightarrow$ ST (12 15) |

Internal Register Load and Store Instructions

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | OP CODE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |


| MNEMONIC | MEANING | OP CODE | STATUS <br> BITS <br> AFFECTED | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| STST | Store status register | $00000010110 \times$ |  | $($ ST $) \rightarrow(W R)$ |
| LST | Load status register | 000000001000 | $0 \quad 15$ | $(W R) \rightarrow(S T)$ |
| STWP | Store workspace pointer | $00000010101 \times$ |  | $(W P) \rightarrow(W R)$ |
| LWP | Load workspace pointer | 000000001001 |  | $(W R) \rightarrow(W P)$ |

$x \equiv$ don't care

## Extended Operation (XOP) Instruction

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 1 | 0 | 1 | 1 |  | D |  | $\mathrm{T}_{\mathrm{S}}$ |  |  | S |  |  |  |

The TS and $S$ fields provide multiple-mode addressing capability for the source operand When the XOP is executed, ST6 is set and the following transfers occur

$$
\begin{aligned}
\overline{\text { MPEN }} & \rightarrow 1 \\
(4016+4 \times \mathrm{D}) & \rightarrow(\text { WP }) \\
(4216+4 \times \mathrm{D}) & \rightarrow(\mathrm{PC}) \\
(\mathrm{ST7} \mathrm{ST} 11) & \rightarrow 00000 \\
\text { SA } & \rightarrow \text { (New WR11) } \\
\text { (Old WP) } & \rightarrow \text { (New WR13) } \\
\text { (Old PC) } & \rightarrow \text { (New WR14) } \\
\text { (Old ST) } & \rightarrow \text { (New WR15) }
\end{aligned}
$$

The SBP9989 does not test interrupt requests (INTREO) upon completion of the XOP instruction

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | $\begin{array}{lllll}11 & 12 & 13 & 14 & 15\end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 |  |

The RTWP instruction causes the following transfers to occur-

$$
\begin{aligned}
& (\text { WR15 }) \rightarrow(S T) \\
& (\text { WR14 }) \rightarrow(\text { PC }) \\
& (\text { WR13 }) \rightarrow(W P)
\end{aligned}
$$

## External Instructions

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: |
| OP CODE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

External instructions cause the three most significant address lines (AO A2) to be set to the levels described below, address lines A3 - A7 to be set to the 5 -bit value specified in the $C$ field of the instruction, the DBIN output to be activated, and the CRUCLK line to be pulsed, allowing external control functions to be initiated.

| MNEMONIC ${ }^{\dagger}$ | MEANING | OP CODE | STATUS BITS AFFECTED | DESCRIPTION | ADDRESS BUS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | A0 | A1 | A2 |
| IDLE | Idie | 00000011010 |  | Suspend S8P9989 instruction execution until an Interrupt, $\overline{\text { LOAD }}$ or $\overline{R E S E T}$ occurs | L | H | L. |
| RSET | Reset | 00000011011 | $7 \quad 15$ | $0 \rightarrow$ ST (7 15) | L | H | H |
| CKOF | User defined | 00000011110 |  |  | H | H | $L$ |
| CKON | User defined | 00000011101 |  |  | H | $L$ | H |
| LREX | User defined | 00000011111 |  |  | H | H | H |

${ }^{\dagger}$ The mnemonics associated with these instructions relate to their use in the $\mathrm{TI} 990 / 4$ minicomputer and have no special significance

## Microinstruction Cycle

The SBP9989 includes circuitry which will indicate the completion of a microinstruction cycle. Designated as the $\overline{\mathrm{CYCEND}}$ function, it provides CPU status that can simplify system design. The $\overline{\mathrm{CYCEND}}$ output will go to a low logic level as a result of the low-to-high transition of each clock pulse which initiates the last clock cycle of a microinstruction

## nstruction Execution Times

Instruction execution times for the SBP9989 are a function of

1) Clock cycle time, tC
2) Addressing mode used where operands have multiple addressing mode capability
3) Number of wat states required per memory access
4) Number of wart states required per CRU operation

The following instruction execution listing provides the number of clock cycles memory-access cycles and CRU operations required to execute each SBP9989 instruction For instructions with multiple addressing modes for etther or both operands the table lists the number of clock cycles and memory access cycles with all operands addressed in the workspace register mode To determine the additional number of clock cycles and memory-access cycles required for modified addressing, add the appropriate values from Table 4 For the five CRU instructions (i e , STCR LDCR, SBO, SBZ, TB), the table lists the number of clock cycles assuming no wat states for CRU operations To determine the additional number of CRU-related clock cycles, add one ciock cycle for each wat state incurred as the result of a CRU operation The total execution time for an instruction is given by

$$
T=t_{C}\left[C_{T}+\left(W_{M} \times M_{T}\right)\right]+t_{C}\left(W_{C} \times P\right)
$$

where
$T=$ total instruction execution time,
${ }^{\mathrm{t}} \mathrm{C}=$ clock cycle time,
$\mathrm{C}_{\mathrm{T}}=$ total number of clock cycles (clock cycles for instruction execution plus clock cycles for address modification).
$W_{M}=$ number of required walt states per memory access,
$M_{T}=$ total number of memory-accesses (memory accesses for instruction execution plus memory accesses for address modification).
$\mathbf{P}=$ number of CRU operations,
$W_{C}=$ number of required walt states per CRU operation
As an example, the instruction MOVB is used in a system with $t^{C} C=0250 \mu$ s and no wait states are required to access memory. Both operands are addressed in the workspace register mode. The instruction execution time is given by

$$
\begin{aligned}
T & =t_{C}\left[C_{T}+\left(W_{M} \times M_{T}\right)\right]+t_{C}\left(W_{C} \times P\right) \\
& =0.250[12+(0 \times 4)]+0250(0)=3 \mu \mathrm{~s}
\end{aligned}
$$

If two watt states per memory access were required, the execution time would become

$$
\mathrm{T}=0250[12+(2 \times 4)]+0250(0)=5 \mu \mathrm{~s}
$$

If the source operand were addressed in the symbolic mode and two wait states were required

$$
\begin{aligned}
\mathrm{T} & =\mathrm{t}_{\mathrm{C}}\left[\mathrm{C}_{\mathrm{T}}+\left(\mathrm{W}_{\mathrm{M}} \times \mathrm{M}_{\mathrm{T}}\right)\right]+\mathrm{t}_{\mathrm{C}}\left(\mathrm{~W}_{\mathrm{C}} \times \mathrm{P}\right) \\
\mathrm{C}_{\mathrm{T}} & =12+6=18 \\
\mathrm{M}_{\mathrm{T}} & =4+1=5 \\
\mathrm{~T} & =0250[18+(2 \times 5)]+0250(0)=7 \mu \mathrm{~s}
\end{aligned}
$$

INSTRUCTION EXECUTION

| INSTRUCTION | CLOCK CYCLES |  | MEMORY CYCLES |  | ADDRESS MODIFICATION |  | CRU OPERATIONS P |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | SBP9989 | $\triangle$ FROM SBP9900A | SBP9989 | $\triangle$ FROM S8P9900A |  |  |  |
|  |  |  |  |  | SOURCE | DEST. |  |
| A | 12 | -2 | 4 |  | Table 4 | Table 4 |  |
| $A B$ | 12 | -2 | 4 |  | Table 4 | Table 4 |  |
| ABS ( $\mathrm{MSB}=0$ ) | 10 | -2 | 2 |  | Table 4 |  |  |
| ( $\mathrm{MSB}=1$ ) | 14 |  | 3 |  | Table 4 |  |  |
| Al | 14 |  | 4 |  |  |  |  |
| ANDI | 14 |  | 4 |  |  |  |  |
| B | 6 | -2 | 1 | -1 | Table 4 |  |  |
| BL | 10 | -2 | 2 | -1 | Table 4 |  |  |
| BLWP | 24 | -2 | 6 |  | Table 4 |  |  |
| C | 12 | -2 | 3 |  | Table 4 | Table 4 |  |
| CB | 12 | $-2$ | 3 |  | Table 4 | Table 4 |  |
| Cl | 12 | -2 | 3 |  |  |  |  |
| CKOF | 10 | -2 | 1 |  |  |  |  |
| CKON | 10 | -2 | 1 |  |  |  |  |
| CLR | 8 | -2 | 2 | -1 | Table 4 |  |  |
| COC | 12 | -2 | 3 |  | Table 4 |  |  |
| CZC | 12 | -2 | 3 |  | Table 4 |  |  |
| DEC | 10 |  | 3 |  | Table 4 |  |  |
| DECT | 12 |  | 3 |  | Table 4 |  |  |
| DIV (ST4 is set) | 20 | +4 | 4 | +1 | Table 4 |  |  |
| (ST4 is reset) | 56 | -38 to -68 | 6 |  | Table 4 |  |  |
| DIVS (ST4 is set) | 56 | new | 4 |  | Table 4 |  |  |
| (ST4 is reset) | 60 | new | 6 |  | Table 4 |  |  |
| IDLE | 10 | -2 | 1 |  |  |  |  |
| INC | 10 |  | 3 |  | Table 4 |  |  |
| INCT | 10 |  | 3 |  | Table 4 |  |  |
| INV | 10 |  | 3 |  | Table 4 |  |  |
| JUMP (PC is changed) | 6 | -4 | 1 |  |  |  |  |
| (PC is not changed) | 6 | -2 | 1 |  |  |  |  |
| LDCR ( $C=0)$ | 48 | -4 | 3 |  | Table 4 |  | 16 |
| $(1<C \leqslant 15)$ | $16+2 \mathrm{C}$ | -4 | 3 |  | Table 4 |  | C |
| L. 1 | 12 |  | 3 |  |  |  |  |
| LIMI | 12 | -2 | 2 |  |  |  |  |
| LREX | 10 | -2 | 1 |  |  |  |  |
| LST | 10 | new | 2 |  |  |  |  |
| LWP | 10 | new | 2 |  |  |  |  |
| LWPI | 12 | +2 | 2 |  |  |  |  |
| MOV | 10 | -4 | 3 | -1 | Table 4 | Table 4 |  |
| MOVB | 12 | -2 | 4 |  | Table 4 | Table 4 |  |
| MPY | 52 |  | 5 |  | Table 4 |  |  |
| MPYS | 56 | new | 5 |  | Table 4 |  |  |
| NEG | 12 |  | 3 |  | Table 4 |  |  |
| ORI | 14 |  | 4 |  |  |  |  |
| RSET | 10 | -2 | 1 |  |  |  |  |
| RTWP | 16 | +2 | 4 |  |  |  |  |


| INSTRUCTION | CLOCK CYCLES |  | MEMORY CYCLES |  | ADDRESS MODIFICATION |  | CRU OPERATIONS P |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | SBP9989 | $\begin{array}{r} \triangle \text { FROM } \\ \text { SBPG900A } \end{array}$ | SBP9989 | $\begin{gathered} \triangle F R O M \\ \text { SBP9900A } \end{gathered}$ |  |  |  |
|  |  |  |  |  | SOURCE | DEST |  |
| S | 12 | -2 | 4 |  | Table 4 | Table 4 |  |
| SB | 12 | -2 | 4 |  | Table 4 | Table 4 |  |
| SBO | 12 |  | 2 |  |  |  | 1 |
| SBZ | 12 |  | 2 |  |  |  | 1 |
| SETO | 8 | -2 | 2 | -1 | Table 4 |  |  |
| SHIFTS |  |  |  |  |  |  |  |
| ( $\mathrm{C} \neq 0$ ) | $12+2 \mathrm{C}$ |  | 3 |  |  |  |  |
| ( $\mathrm{C}-0.8$ Bits (12-15) |  |  |  |  |  |  |  |
| of $W R O=0)$ | 52 |  | 4 |  |  |  |  |
| (C-0, Bits (12 15) |  |  |  |  |  |  |  |
| of WRO $\neq 0$ ) | Note 1 |  | 4 |  |  |  |  |
| soc | 12 | -2 | 4 |  | Table 4 | Table 4 |  |
| soce | 12 | -2 | 4 |  | Table 4 | Table 4 |  |
| STCR ( $C=0$ ) | 56 | -4 | 4 |  | Table 4 |  | 16 |
| $(1 \leqslant C \leqslant 8)$ | 40 | -2 to-4 | 4 |  | Table 4 |  | c |
| $(9 \leqslant C \leqslant 15)$ | 56 | -2 | 4 |  | Table 4 |  | c |
| STST | 8 |  | 2 |  |  |  |  |
| STWP | 8 |  | 2 |  |  |  |  |
| SWPB | 10 |  | 3 |  | Table 4 |  |  |
| SZC | 12 | -2 | 4 |  | Table 4 | Table 4 |  |
| SZCB | 12 | -2 | 4 |  | Table 4 | Table 4 |  |
| TB | 12 |  | 2 |  |  |  | 1 |
| ${ }^{*}$ | 4 |  | 1 |  | Table 4 |  |  |
| XOP | 28 | -8 | 7 | -1 |  |  |  |
| XOR | 12 | -2 | 4 |  | Table 4 |  |  |
| Reset function | 22 | -4 | 5 |  |  |  |  |
| Load function | 20 | -2 | 5 |  |  |  |  |
| Interrupt |  |  |  |  |  |  |  |
| Context Switch | 20 | -2 | 5 |  |  |  |  |
| UNDEFINED OP CODES ** |  |  |  |  |  |  |  |
| ${ }^{00000} 16-007 F_{16}$ |  |  |  |  |  |  |  |
| $0040_{16}-017 \mathrm{~F}_{16}$ |  |  |  |  |  |  |  |
| $\begin{aligned} & 0320_{16}-033 F_{16} \\ & 0780_{16}-07 F_{16} \end{aligned}$ | 24 | +18 | 6 | +5 |  |  |  |
| $\mathrm{OCOO}_{16}{ }^{\text {- }} \mathrm{OFFF}_{16}$ |  |  |  |  |  |  |  |

*Execution time is added to the execution time of the source address
**Execution time includes time to perform a trap (i e, subroutine call) operation resulting from XIPP being inactive NOTE 1 The number of clock cycles is twenty plus twice the value of Bits (12 15) of WRO

TABLE 4 - ADDRESS MODIFICATION

\left.|  | CLOCK CYCLES |  | MEMORY |
| :--- | :---: | :---: | :---: |
|  |  |  |  |$\right]$

## MACHINE CYCLES

This section completes the description of instruction execution, by giving the individual instruction execution cycles. Each machine cycle consists of two or more clock cycles (depending upon addressing mode) as defined herein. Three categories describe the 9989 machine cycles: ALU cycle, Memory cycie and CRU cycle.

## ALU Cycle

The ALU cycle performs an internal operation of the microprocessor. The memory interface control signals and CRU control signals are not affected by the execution of an ALU cycle, which takes two clock cycles to execute.

## Memory Cycle

The memory cycle primarily performs a data transfer between the microprocessor and the external memory device. Appropriate memory bus control signals are generated by the microprocessor as a result of a memory cycle execution. The memory cycle takes $2+W$ (where $W$ is number of wait states) clock cycles to execute.

## CRU Cycle

The CRU cycle performs a bit transfer between the microprocessor and $I / O$ devices It takes two clock cycles to execute. The address of the CRU bit is set up during the first clock cycle. For an input operation the CRUIN line is sampled by the microprocessor during the third clock cycle for an output operation, the data bit is set up on the CRUOUT line at the same time the address is set up. The CRUCLK line is pulsed during the second clock cycle of CRU output cycle.

A special feature of the 9989's CRU operation not available on its forerunner the SBP9900A, is the capability to insert wait states. The 9989 will sample the READY line at the beginning of the second clock cycle.

## SBP9989 MACHINE CYCLE SEQUENCES

Most SBP9989 instructions consıst of two parts 1) the data derivation and 2) operation execution The data derivat'on sequence depends on the addressing mode for the data Since the addressing modes are common to all instructions, the data derivation sequence is the same for the same addressing mode, regardiess of the instruction Therefore data derivation sequences are described first These are then referenced in appropriate sequence in the instruction execution description.

## Data Derivation Sequence

| WORKSPACE REGISTER |  |
| :---: | :---: |
| CYCLE | TYPE |
| 0 | Memory read |

NOTE
Fastest addressing mode, no additional clock cycles for Source or Destination Acquisition Read will enther have already occurred in the op-code instruction Fetch or at appropriate operand Fetch Therefore $\mathrm{Ns}=\mathrm{Nd}=0$ when using Workspace Register Addressing Mode

WORKSPACE REGISTER INDIRECT

| CYCLE | TYPE | NOTE |
| :---: | :--- | :---: |
| 1 | Memory read | Ns $=\mathrm{Nd}=2$ |
| 2 | ALU |  |

WORKSPACE REGISTEA INDIRECT AUTO-INCREMENT

| CYCLEE | TYPE | NOTE |
| :---: | :--- | :---: |
| 1 | Memory read | Ns $=\mathrm{Nd}=3$ |
| 2 | ALU |  |
| 3 | Memory write |  |

## SYMBOLIC

CYCLE
TYPE
ALU
NOTE
: ALU $\mathrm{N}_{5}=\mathrm{Nd}=3$

2
Memory read
3 ALU

INDEXED

| CYCLE | TYPE | NOTE |
| :---: | :--- | :---: |
| 1 | Memory read | Ns $=$ Nd $=3$ |
| 2 | Memory read |  |
| 3 | ALU |  |

$A, A B, M O V B, S, S B, S O C, S O C B, S Z C, S Z C B$

| CYCLE | TYPE |
| :--- | :--- |
| 1 | Memory read |
| 2 | ALU |
| $N_{s}$ | Source acquisition |
| $3+\mathrm{Ns}^{2}$ | Memory read |
| Nd | Destination acquistion |
| $4+\mathrm{Ns}^{+}+\mathrm{Nd}$ | Memory read |
| $5+\mathrm{Ns}+\mathrm{Nd}$ | ALU |
| $6+\mathrm{Ns}+\mathrm{Nd}$ | Memory write |


| AI, ANDI, ORI | TYPE |
| :---: | :--- |
| CYCLE | Memory read |
| 1 | ALU |
| 2 | ALU |
| 3 | Memory read |
| 4 | Memory read |
| 5 | ALU |
| 6 | Mernory write |

$A B S(M S B=1)$

| CYCLE | TYPE |
| :--- | :--- |
| 1 | Memory read |
| 2 | ALU |
| Ns | Source acquisition |
| $3+\mathrm{Ns}$ | Memory read |
| $4+\mathrm{Ns}$ | ALU |
| $5+\mathrm{Ns}$ | ALU |
| $6+\mathrm{Ns}$ | ALU |
| $7+\mathrm{Ns}$ | Memory write |

ABS (MSB $=0$ )

| CYCLE | TYPE |
| :--- | :--- |
| 1 | Memory read |
| 2 | ALU |
| Ns | Source acquisition |
| $3+\mathrm{Ns}^{2}$ | Memory read |
| $4+\mathrm{Ns}$ | ALU |
| $5+\mathrm{Ns}$ | ALU |


| BL |  |
| :---: | :--- |
| CYCLE | TYPE |
| 1 | Memory read |
| 2 | ALU |
| Ns | Source acquisition |
| $3+$ Ns | ALU |
| $4+$ Ns | ALU |
| $5+$ Ns | Memory write |


| Cl |  |
| :---: | :--- |
| CYCLE | TYPE |
| 1 | Memory read |
| 2 | ALU |
| 3 | Memory read |
| 4 | Memory read |
| 5 | ALU |
| 6 | ALU |


| BLWP |  |
| :---: | :--- |
| CYCLE | TYPE |
| 1 | Memory read |
| 2 | ALU |
| Ns | Source acquisition |
| $3+\mathrm{Ns}$ | Memory read |
| $4+\mathrm{Ns}$ | ALU |
| $5+\mathrm{Ns}$ | ALU |
| $6+\mathrm{Ns}$ | Memory write |
| $7+\mathrm{Ns}$ | ALU |
| $8+\mathrm{Ns}^{2}$ | Memory write |
| $9+\mathrm{Ns}$ | ALU |
| $10+\mathrm{Ns}$ | Memory write |
| $11+\mathrm{Ns}$ | Memory read |
| $12+\mathrm{Ns}$ | ALU |


| C, CB, COC, CZC |  |
| :--- | :--- |
| CYCLE | TYPE |
| 1 | Memory read |
| 2 | ALU |
| Ns | Source acquisition |
| $3+\mathrm{Ns}$ | Memory read |
| Nd | Destination acquisition |
| $4+\mathrm{Ns}+\mathrm{Nd}$ | Memory read |
| $5+\mathrm{Ns}+\mathrm{Nd}$ | ALU |
| $6+\mathrm{Ns}+\mathrm{Nd}$ | ALU |


| CKOF, CKON, LREX, IDLE, ASET |  |
| :---: | :--- |
| CYCLE | TYPE |
| 1 | Memory read |
| 2 | ALU |
| 3 | ALU |
| 4 | ALU |
| 5 | CRU |


| CLR |  |
| :---: | :--- |
| CYCLE | TYPE |
| 1 | Memory read |
| 2 | ALU |
| Ns | Source acquisition |
| $3+\mathrm{Ns}$ | ALU |
| $4+\mathrm{Ns}$ | Memory write |

DEC, DECT, INC, INCT, INV, SWPB

| CYCLE | TYPE |
| :---: | :--- |
| 1 | Memory read |
| 2 | ALU |
| $\mathrm{N}_{5}$ | Source acquisition |
| $3+\mathrm{Ns}$ | Memory read |
| $4+\mathrm{Ns}$ | ALU |
| $5+\mathrm{Ns}$ | Memory write |


| DIV $(S T 4=0)$ |  | DIV $(S T 4=1)$ |  |
| :---: | :---: | :---: | :---: |
| CYCLE | TYPE | CyCle | TYPE |
| 1 | Memory read | 1 | Memory read |
| 2 | ALU | 2 | ALU |
| Ns | Source acquisition | Ns | Source acquistion |
| $3+\mathrm{Ns}$ | Memory read | $3+\mathrm{Ns}$ | Memory read |
| $4+\mathrm{Ns}$ | Memory read | $4+\mathrm{Ns}$ | Memory read |
| $5+\mathrm{Ns}$ | ALU | $5+\mathrm{Ns}$ | ALU |
| $6+\mathrm{Ns}$ | ALU | $6+\mathrm{Ns}$ | ALU |
| $7+\mathrm{Ns}$ | Memory read | $7+\mathrm{Ns}$ | Memory read |
| $8+\mathrm{Ns}$ | ALU | $8+\mathrm{Ns}$ | ALU |
| $9+\mathrm{Ns}_{5}$ | ALU | $9+\mathrm{Ns}$ | AtU |
| $10+\mathrm{Ns}$ | (14 ALU cycles) | $10+\mathrm{Ns}$ | ALU |
| $24+\mathrm{Ns}$ | ALU |  |  |
| $25+N s$ | ALU |  |  |
| $26+\mathrm{Ns}$ | Memory write |  |  |
| $27+\mathrm{Ns}^{\text {}}$ | AlU |  |  |
| $28+\mathrm{Ns}$ | Memory write |  |  |
| DIVS (ST4 = 1) |  | ILLOP |  |
| CYCLE | TYPE | CYCLE | TYPE |
| 1 | Memory read | 1 | Memory read |
| 2 | ALU | 2 | ALU |
| Ns | Source acquisition | 3 | ALU |
| $3+\mathrm{Ns}$ | Memory read | 4 | Memory read |
| $4+\mathrm{Ns}$ | ALU | 5 | ALU |
| $5+\mathrm{Ns}$ | Memory read | 6 | Memory write |
| $6+\mathrm{Ns}$ | ALU | 7 | ALU |
| $7+\mathrm{Ns}$ | Memory read | 8 | Memory write |
| $8+\mathrm{Ns}$ | ALU | 9 | ALU |
| $9+\mathrm{Ns}$ | ALU | 10 | Memory write |
| $10+\mathrm{Ns}$ | (14 ALU cycles) | 11 | Memory read |
| $24+\mathrm{Ns}$ | ALU | 12 | ALU |
| $25+\mathrm{Ns}^{5}$ | ALU |  |  |
| $26+N s$ | ALU |  |  |
| $27+N s$ | ALU |  |  |
| $28+\mathrm{Ns}$ | Memory write |  |  |
| LDCR |  | LI |  |
| CYCLE | TYPE | cycle | TYPE |
| 1 | Memory read | 1 | Memory read |
| 2 | ALU | 2 | ALU |
| Ns | Source acquisition | 3 | ALU |
| $3+\mathrm{Ns}$ | Memory read | 4 | Memory read |
| $4+\mathrm{Ns}$ | ALU | 5 | ALU |
| $5+\mathrm{Ns}$ | ALU | 6 | Memory write |
| $6+\mathrm{Ns}$ | Memory read |  |  |
| $7+\mathrm{Ns}$ | ALU |  |  |
| Nc | $C R U($ for $\mathrm{C}=0, \mathrm{Nc}=16$ ) (for $1 \leqslant C \leqslant 15, \mathrm{Ne}_{\mathrm{C}}=\mathrm{C}$ ) |  |  |
| $8+N_{s}+$ | ALU |  |  |

ILLOP

ALU

Memory read
ALU
Memory write
ALU
Memory write
ALU
Memory write
Memory read
ALU

Memory read
ALU
ALU

ALU
Memory write

DIVS $(S T 4=0)$

| CYCLE | TYPE |
| :---: | :--- |
| 1 | Memory read |
| 2 | ALU |
| Ns | Source acquisition |
| $3+\mathrm{Ns}$ | Memory read |
| $4+\mathrm{Ns}$ | ALU |
| $5+\mathrm{Ns}$ | Memory read |
| $6+\mathrm{Ns}$ | ALU |
| $7+\mathrm{Ns}$ | Memory read |
| $8+\mathrm{Ns}$ | ALU |
| $9+\mathrm{Ns}$ | ALU |
| $10+\mathrm{Ns}$ | (14 ALU cycles) |
| $24+\mathrm{Ns}$ | ALU |
| $25+\mathrm{Ns}$ | ALU |
| $26+\mathrm{Ns}$ | ALU |
| $27+\mathrm{Ns}^{2}$ | ALU |
| $28+\mathrm{Ns}_{s}$ | Memory write |
| $29+\mathrm{Ns}$ | ALU |
| $30+\mathrm{Ns}$ | Memory write |


| JUMPS |  |
| :---: | :--- |
| CYCLE | TYPE |
| 1 | Memory read |
| 2 | ALU |
| 3 | ALU |


| LOAD, INTERRUPT CONTEXT SWITCH |  | LST, LWP |  |
| :---: | :---: | :---: | :---: |
| cycle | TYPE | CYCLE | TYPE |
| 1 | ALU | 1 | Memory read |
| 2 | Memory read | 2 | ALU |
| 3 | ALU | 3 | Memory read |
| 4 | Memory write | 4 | ALU |
| 5 | ALU | 5 | ALU |
| 6 | Memory write |  |  |
| 7 | ALU |  |  |
| 8 | Memory write |  |  |
| 9 | Memory read |  |  |
| 10 | ALU |  |  |

## MOV (word)

| CYCLE | TYPE |
| :--- | :--- |
| 1 | Memory read |
| 2 | ALU |
| Ns | Source acquistion |
| $3+\mathrm{Ns}$ | Memory read |
| Nd | Destination acquisition |
| $4+\mathrm{Ns}+\mathrm{Nd}$ | ALU |
| $5+\mathrm{Ns}+\mathrm{Nd}$ | Memory write |
|  |  |
|  |  |


| MPYS (signed) | TYPE |
| :---: | :--- |
| CYCLE | Memory read |
| 1 | ALU |
| 2 | Mource acquisition |
| Ns | Memory read |
| $3+N_{s}$ | ALU |
| $4+N_{s}$ | ALU |
| $5+N_{s}$ | Memory read |
| $6+N_{s}$ | ALU |
| $7+N_{s}$ | (15 ALU cycles) |
| $8+N_{s}$ | ALU |
| $23+N_{s}$ | Memory write |
| $24+N_{s}$ | ALU |
| $25+N_{s}$ | ALU |
| $26+N_{s}$ | ALU |
| $27+N_{s}$ | ALU |
| $28+N_{s}$ | Memory write |

## NEG

| CYCLE | TYPE |
| :---: | :--- |
| 1 | Memory read |
| 2 | ALU |
| Ns | Source acquisition |
| $3+\mathrm{Ns}$ | Memory read |
| $4+\mathrm{Ns}$ | ALU |
| $5+\mathrm{Ns}$ | ALU |
| $6+\mathrm{Ns}_{s}$ | Memory write |


| $\overline{\operatorname{RESET}}$ (hardware) |  | RTWP |  |
| :---: | :---: | :---: | :---: |
| CYCLE | TYPE | cycle | TYPE |
| 1 | ALU | 1 | Memory read |
| 2 | ALU | 2 | ALU |
| 3 | Memory read | 3 | ALU |
| 4 | ALU | 4 | Memory read |
| 5 | Memory write | 5 | Memory read |
| 6 | ALU | 6 | Memory read |
| 7 | Memory write | 7 | ALU |
| 8 | ALU | 8 | ALU |
| 9 | Memory write |  |  |
| 10 | Memory read |  |  |
| 11 | ALU |  |  |

SBO, SBZ, TB

| CYCLE | TYPE |
| :---: | :--- |
| 1 | Memory read |
| 2 | ALU |
| 3 | ALU |
| 4 | Memory read |
| 5 | ALU |
| 6 | CRU |


| SETO |  |
| :--- | :--- |
| CYCLE | TYPE |
| 1 | Memory read |
| 2 | ALU |
| Ns | Source acquisition |
| $3+N s$ | ALU |
| $4+N s$ | Memory write |


| SHIFTS $(C=0)$ |  |
| :--- | :--- |
| CYCLE | TYPE |
| 1 | Memory read |
| 2 | ALU |
| 3 | Memory read |
| 4 | ALU |
| 5 | ALU |
| 6 | Memory read |
| 7 | ALU |
| 8 | ALU |
| Nc | (If WROIBits $12 \quad 15)=0$ Nc 16 ) |
|  | lotherwise Nc WROIBits 12 15) |
| $9+$ Nc | Memorywrite |
| $10+$ Nc | ALU |


| SHIFTS $(C \neq 0)$ |  |
| :--- | :--- |
| CYCLE | TYPE |
| 1 | Memory read |
| 2 | ALU |
| 3 | Memory Iead |
| 4 | ALU |
| Nc | (Ne -C ALU cycles) |
| $5+\mathrm{Nc}$ | Memory write |
| $6+\mathrm{Nc}$ | ALU |


| STST, STWP |  |
| :---: | :--- |
| CYCLE | TYPE |
| 1 | Memory read |
| 2 | ALU |
| 3 | ALU |
| 4 | Memory write |


| XOR |  |
| :--- | :--- |
| CYCLE | TYPE |
| 1 | Memory read |
| 2 | ALU |
| Ns | Source acquisition |
| $3+\mathrm{Ns}_{5}$ | Memory read |
| $4+\mathrm{Ns}$ | Memory read |
| $5+\mathrm{Ns}_{s}$ | ALU |
| $6+\mathrm{Ns}$ | Memory write |

## Leaving a Hold State

When the SBP9989 leaves a hold state, the time required for the signals to return to their proper levels is different from the other delay times This difference is on the order of 10 to 20 nanoseconds. If your system does not use hold states or can tolerate the longer delay tımes, there will be no problems if these delay times are too long, add a wait state at the end of a hold state to allow the signals to come to their proper levels as shown below.


## POWER SOURCE

12 L is a current-injected logic. When the injector and ground pins are placed across a curve tracer, the processor V I characteristic will resemble that of a silicon diode Although any voltage or current source capable of supplying the desired current at the injector voltage required will suffice, a regulated current source is recommended This is because the injector voltage will vary over the temperature range One approach to a suitable, highly stable regulator is shown th the figure below.



## ELECTRICAL DATA

## INPUT/OUTPUT STRUCTURE

## Interfacing

The input/output (I/O) accommodations have been designed for TTL compatibility. Direct interfacing is supportable by entıre families of support devices. System designers will note that propagation delays, set-up time, and hold time requirements do not depend on the frequency of operation.

## Input Circuit

An input clamping diode is incorporated to limit negative excursions (ringing) when the device is on the end a transmıssion line. Since the input circuit is independent of injector current, input threshold compatibility is maintained over the entire speed/power range. This circuit provides a high impedance characteristic to reduce input loading and improve the low-logic level input noise immunity over some standard TTL inputs. Full compatibility is maintaned with virtually all 5 -volt-logic families even when the device is powered down (injector current reduced).

## Termınating Unused Inputs

Inputs which are selected to be hardwired to a low logic level may be connected directly to ground. Inputs selected to be hardwired to a high logic level may be connected directly to +5 volts.

## Output Curcuit

The output circuit selected is an injection open-collector transistor Since this transistor is injected, output sourcing capability is directly related to injector current. In other words, the number of loads which may be sourced by an output is directly reduced as injector current is reduced.

EQUIVALENT SCHEMATICS
EQUIVALENT OF EACH INPUT

## ABSOLUTE MAXIMUM RATINGS


*These values may require modification to observe the rated case temperature range Thermal resistance junction to-case is typically $13^{\circ} \mathrm{C}$ ' W

RECOMMENDED OPERATING CONDITIONS

|  |  | MIN | NOM | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply current, ICC |  | 380 | 400 | 420 | mA |
| High-level output voltage, $\mathrm{V}_{\mathrm{OH}}$ |  |  |  | 55 | $\checkmark$ |
| Low-level output current, 1OL |  |  |  | 16 | mA |
| Clock frequency, fclock |  | 0 |  | 44 | MH2 |
| Width of clock puise, $\mathrm{t}_{\mathrm{w}}$ |  | 114 |  |  | ns |
| Clock rise time, $\mathrm{t}_{\text {r }}$ |  |  |  | 20 | ns |
| Clock fall tume, $\mathrm{tf}^{\text {f }}$ |  |  |  | 20 | ns |
| Setup time, $\mathrm{t}_{\text {su }}$ | HOLD <br> READY <br> DO DIS <br> CRUIN <br> INTREO <br> ICO IC3 <br> $\overline{X I P P}$ <br> LOAD <br> RESET | 0 25 45 70 55 55 50 20 0 |  |  | ns |
| Hold time, th | HOLD <br> READY <br> DO D15 <br> CRUIN <br> INTREO <br> ICO- IC3 <br> $\overline{\mathrm{X} \mid \mathrm{PP}}$ <br> COAD <br> RESET | $\begin{array}{r} 25 \\ 30 \\ 35 \\ 25 \\ 30 \\ 30 \\ 5 \\ 25 \\ 45 \\ \hline \end{array}$ |  |  | ns |
| Operating free-air temperature, | SBP9989NJ, SBP9989NFD | -55 |  | 125 |  |
| , | SBP9989CJ | 0 |  | 70 |  |

ELECTRICAL CHARACTERISTICS OVER RECOMMENDED OPERATING TEMPERATURE RANGE

| PARAMETER |  |  | TEST CONDITIONS ${ }^{+}$ |  | MIN | TYP | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{1 \mathrm{H}}$ | High-level input voltage |  | ${ }^{1} \mathrm{CC}=\mathrm{NOM}$ |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  | ${ }^{1} \mathrm{CC}=$ NOM |  |  |  | 07 | V |
| $V_{\text {IK }}$ | Input clamp voitage |  | $\mathrm{I}_{\mathrm{CC}}=\mathrm{NOM}$, | $\mathrm{l}_{\mathrm{iH}}=-12 \mathrm{~mA}$ |  |  | -15 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current | 1/O Pins | $\begin{aligned} & { }^{1} \mathrm{CC}=\mathrm{NOM} \\ & \mathrm{~V}_{1 \mathrm{~L}}=0.7 \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V} . \\ & \mathrm{V}_{\mathrm{OH}}=55 \mathrm{~V} \end{aligned}$ |  |  | 1000 | $\mu \mathrm{A}$ |
|  |  | Other outputs |  |  |  |  | 250 |  |
| $\mathrm{VOL}_{\text {OL }}$ | Low-level output voltage |  | $\begin{aligned} & \mathrm{I}_{\mathrm{CC}}=\mathrm{NOM}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.7 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & V_{I H}=2 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \end{aligned}$ |  |  | 04 | V |
| I/H | Input current | Clock | ${ }^{1} \mathrm{CC}=\mathrm{NOM}$, | $V_{\text {IN }}=24 \mathrm{~V}$ |  |  | 600 | $\mu \mathrm{A}$ |
|  |  | Other inputs |  |  |  |  | 300 |  |
| $\mathrm{V}_{\text {[ } \mathrm{NJ}}$ | Injector voltage |  | ${ }^{1} \mathrm{CC}=\mathrm{NOM}$ |  | 125 |  |  | V |

$\dagger$ For test conditions shown as NOM, see the appropriate value under Recommended Operating Conditions

## SWITCHING CHARACTERISTICS OVER RECOMMENDED OPERATING TEMPERATURE RANGE

| PARAMETER | FROM | TO | TEST CONDITIONS | MiN | TYP MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {t P }}$ | CLK $\uparrow$ | Address bus (A0 A14) | $C_{L}=100 \mathrm{pF}$ |  | 140 | ns |
|  | CLK 1 | Memory map enable (MPEN) |  |  | 140 |  |
|  | CLK $\uparrow$ | Data bus (D0 - D15) |  |  | 140 |  |
|  | CLK $\downarrow$ | Write enable (WE) |  |  | 180 |  |
|  | CLK $\uparrow$ | CVcle end ( $\overline{C Y C E N D}$ ) |  |  | 175 |  |
|  | CLK $\uparrow$ | Data bus in (DBIN) |  |  | 155 |  |
|  | CLK $\dagger$ | Memory enable (MEMEN) |  |  | 140 |  |
|  | CLK ${ }^{\text {* }}$ | tCRU clock (CRUCLK) |  |  | 185 |  |
|  | CLK $\downarrow$ | $\downarrow$ CRU clock (CRUCLK) |  |  | 185 |  |
|  | CLK $\uparrow$ | CRU data out (CRUOUT) |  |  | 175 |  |
|  | CLK $\uparrow$ | Hoid acknowledge (HOLDA) |  |  | 150 |  |
|  | CLK ${ }^{\text {¢ }}$ | Wart |  |  | 140 |  |
|  | CLK ${ }^{\text {¢ }}$ | Instruction Acquisition (IAQ) |  |  | 140 |  |
|  | CLKt | Multıprocessor interlock (MPILCK) |  |  | 145 |  |
|  | CLK $\uparrow$ | Interrupt acknowledge (INTACK) |  |  | 150 |  |
| tPD | CLK $\dagger$ | Address bus (A0-A14) |  |  | 200 | ns |
|  | CLK $\dagger$ | Memory map enable (MPEN) |  |  | 200 |  |
|  | CLK $\uparrow$ | Data bus (D0 - D15) |  |  | 200 |  |
|  | CLKt | Memory enable ( $\overline{\text { MEMEN }}$ ) | a Hold State, |  | 200 |  |
|  | CLK $\uparrow$ | Data bus in (DBIN) | $C_{L}=100 \mathrm{pF}$ |  | 200 |  |
|  | CLK $\uparrow$ | Instruction Acquisition (IAQ) |  |  | 200 |  |




Dimensions are in mulimeters
and paremthetically in inches
4 Contact spacing is 064 (0025) between centers The center is indented with a half cylindrical center with a radus of 020 (0008)


| United Kingdom | France | Germany | Italy |
| :---: | :---: | :---: | :---: |
| Regional Technology Centre | Texas Instruments | Texas Instruments | Texas instruments |
| Texas instruments Ltd | France | Deutschland GmbH | Semiconduttori Italia S.P.A. |
| Manton Lane | Boite Postale 5 | Haggertystrasse 1 | Divisione Semiconduttori |
| BedfordMK417PA | 06270 Villeneuve Loubet | 8050 Freising | Vialle delle Scienze 1 |
| Tel (0234)67466 | Tel (93)200101 | Tel 08161800 | 02015 Cittaducale (Rietl) |
| Telex 82178 | Telex 470127 | Telex 526529 | Te! (0746)6941 |
| Technical Enquiry Service |  |  | Telex 611003 |
| Tel (0234) 223000 |  |  |  |
| Austria | Denmark | Norway | Sweden |
| Texas Instruments GmbH | Texas Instruments AS | Texas Instruments | Texas Instruments |
| Industnestrasse B/16 | Manelundvej 46E | Norway AS | International Trade Corpn |
| A-2345 Brunn/Gebirge | 2730 Herlev | KR August GT 13 | Norra Hamnvagen 3 |
| Tel (02236)846210 | Tel (02) 917400 | Oslo 1 | 10054 Stockholm |
| Telex 79304 | Telex 35123 | Tel (02) 206040 | Tel (08) 235480 |
|  |  | Telex 19628 | Telex 10377 |
| Belgium | Finland | Spain | Switzerland |
| S.A. Texas instruments | Texas instruments | Texas Instruments | Texas instruments |
| Beigium N.V. | Finland OY | Espana S.A. | Switzerland A.G. |
| Raketstrat. | Teollisuuskatu 19D | C/Jose Lazaro Galdiano No 6 | Riedstrasse 6 |
| 100. Rue de la Fusee | PL56 | 16 Madrid | CH-8953 Dietikon |
| 1130 Brussels | 00510 Helsinkı 51 | Tel 12506105 | Tel (01)7402220 |
| Tel (02) 7208000 | Tel (90) 7013133 |  | Telex 56260 |
| Telex 61161 | Telex 121457 |  |  |


[^0]:    * When HOLDA is active, these terminals are high

