TI-990
The TI-990 was a series of 16-bit minicomputers sold by Texas Instruments in the 1970s and 1980s. The TI-990 was a replacement for TI's earlier minicomputer systems, the TI-960 and the TI-980. It had several unique features, and was easier to program than its predecessors.
Features
Workspaces
On the TI-990, registers are stored in memory and are referred to through a hard register called the Workspace Pointer. The concept behind the workspace is that main memory was based on the new semiconductor RAM chips that TI had developed and ran at the same speed as the CPU. This meant that it didn't matter if the "registers" were real registers in the CPU or represented in memory. When the Workspace Pointer is loaded with a memory address, that address is the origin of the "registers."There are three hard registers in the 990; the Workspace Pointer, the Program Counter and the Status register. A context switch entailed the saving and restoring of only the hard registers.
Extended operation
The TI-990 had a facility to allow extended operations through the use of plug in hardware. If the hardware is not present the CPU traps to allow software to perform the function. The operation code allowed for 15 attached devices on a system. Although, device 15 is reserved, by convention, to be used as the systems call entry for user programs to request systems services.Orthogonal instruction set
The TI-990 used a fairly orthogonal instruction set. The basic instruction formats allowed for one, two and three word instructions. The model 990/12 CPU allowed for a four word instruction with the extended mode operations.Architectural details
General register [addressing mode]s
Several registers had special usages that reserve their use, the register and their usages are:- R0 - shift counter, extended mode counter, floating point AC-0
- R1 - floating point AC-1
- R2 - floating point AC-2
- R3 - floating point AC-3
- R11 - XOP pointer, return linkage
- R12 - CRU base address
- R13 - Saved Workspace pointer
- R14 - Saved Program counter
- R15 - Saved Status
TI-990 instructions
Type 1 instructions
The first part of the word specifies the operation to be performed, the remaining two parts provide information for locating the operands.
- MOV
- MOVB
- A
- AB
- S
- SB
- C
- CB
- SZC
- SZCB
- SOC
- SOCB
Type 2 instructions
The first part of the word specifies the operation to be performed, the second part is a relative offset to where to go, for JMP instructions, or the relative offset for CRU bit addressing.
- JMP
- JLT
- JLE
- JEQ
- JHE
- JGT
- JNE
- JNC
- JOC
- JNO
- JOP
- JL
- JH
- SBO
- SBZ
- TB
Type 3 instructions
One part of the word specifies the operation, the second part provides the register, the third part provides information for locating the second operand.
- COC
- CZC
- XOR
- XOP
Type 4 instructions
The first part of the word specifies the operation to be performed, the second part is the bit width of the operation, the third part provides information for locating the second operand.
- LDCR
- STCR
Type 5 instructions
The first part of the word specifies the operation to be performed, the second part is the shift count, the third part specifies the register to shift.
- SRA
- SRL
- SLA
- SRC
Type 6 instructions
The first part specifies the operation to be performed, the second part provides information for locating the second operand.
- BLWP
- B
- X
- CLR
- NEG
- INV
- INC
- INCT
- DEC
- DECT
- BL
- ABS
- SWPB
- SETO
- LDS
- LDD
- BIND
- MPYS
- DIVS
- AR
- CIR
- SR
- MR
- DR
- LR
- STR
- AD
- CID
- SD
- MD
- DD
- LD
- STD
Type 7 instructions
The word specified the operation to be performed.
- IDLE
- RSET
- RTWP
- CKON
- CKOF
- LREX
- EMD
- EINT
- DINT
- CRI
- CDI
- NEGR
- NEGD
- CRE
- CDE
- CER
- CED
- XIT
Type 8 instructions
The first part specifies the operation, the second part specifies the register or mask. The third part, if present, specifies an immediate operand in a second word.
- LIMI
- LI
- AI
- ANDI
- ORI
- CI
- STWP
- STST
- LWPI
- BLSK
Type 9 instructions
One part of the word specifies the operation, the second part provides the register, the third part provides information for locating the second operand.
- MPY
- DIV
Type 10 instruction
The first part specifies the operation, the second part specifies the map file and the third specifies a register.
This instruction supported on the 990/10, 990/10A and 990/12.
- LMF
Type 11 instructions
The first word is the opcode; the first part of the second word is the byte count field, the second part is the destination operand and the third part is the source operand. These instructions supported on the 990/12.
- NRM
- RTO
- LTO
- CNTO
- BDC
- DBC
- SWPM
- XORM
- ORM
- ANDM
- SM
- AM
Type 12 instructions
The first part of the first word is the opcode, the second part of the first word indicates a checkpoint register; the first part of the second word is the byte count field, the second part is the destination operand and the third part is the source operand. These instruction supported on the 990/12.
- SNEB
- CRC
- TS
- CS
- SEQB
- MOVS
- MVSR
- MVSK
- POPS
- PSHS
Type 13 instructions
The first word is the opcode; the first part of the second word is the byte count field, the second part is the shift count and the third part is the source operand. These instructions supported on the 990/12.
- SRAM
- SLAM
Type 14 instructions
The first word is the opcode; the first part of the second word is the position field and the second part is the source operand. These instructions supported on the 990/12.
- TMB
- TCMB
- TSMB
Type 15 instruction
The first part of the first word is the opcode, the second part of the first word indicates a width; the first part of the second word is the position, the second part is the source operand. This instruction supported on the 990/12.
- IOF
Type 16 instructions
The first part of the first word is the opcode, the second part of the first word indicates a width; the first part of the second word is the position, the second part is the destination operand and the third part is the source operand. These instructions supported on the 990/12.
- INSF
- XV
- XF
Type 17 instructions
The first word is the opcode; the first part of the second word is the value field and the second part is the register and the third part is the relative offset. These instructions supported on the 990/12.
- SRJ
- ARJ
Type 18 instructions
The first part of the word is the opcode and the second part is the register specification. These instructions supported on the 990/12.
- STPC
- LIM
- LST
- LWP
- LCS
Type 19 instruction
The first word is the opcode; the first part of the second word is the destination operand and the second part is the source operand. This instruction supported on the 990/12.
- MOVA
Type 20 instructions
The first word is the opcode; the first part of the second word is the condition code field, the second part is the destination operand and the third part is the source operand. These instructions supported on the 990/12.
- SLSL
- SLSP
Type 21 instruction
The first part of the first word is the opcode, the second part of the first word specifies the destination length; the first part of the second word specifies the source length, the second part is the destination operand and the third part is the source operand. This instruction supported on the 990/12.
- EP
Assembly Language Programming Example
IDT 'HELLO'
TITL 'HELLO - hello world program'
*
DXOP SVC,15 Define SVC
TMLUNO EQU 0 Terminal LUNO
*
R0 EQU 0
R1 EQU 1
R2 EQU 2
R3 EQU 3
R4 EQU 4
R5 EQU 5
R6 EQU 6
R7 EQU 7
R8 EQU 8
R9 EQU 9
R10 EQU 10
R11 EQU 11
R12 EQU 12
R13 EQU 13
R14 EQU 14
R15 EQU 15
*
DATA WP,ENTRY,0
*
* Workspace
*
WP DATA 0 R0
DATA 0 R1
DATA >1600 R2 - End of program SVC
DATA >0000 R3 - Open I/O opcode
DATA >0B00 R4 - Write I/O opcode
DATA >0100 R5 - Close I/O opcode
DATA STRING R6 - Message address
DATA STRLEN R7 - Message length
DATA 0 R8
DATA 0 R9
DATA 0 R10
DATA 0 R11
DATA 0 R12
DATA 0 R13
DATA 0 R14
DATA 0 R15
*
* Terminal SVC block
*
TRMSCB BYTE 0 SVC op code
TRMERR BYTE 0 Error code
TRMOPC BYTE 0 I/O OP CODE
TRMLUN BYTE TMLUNO LUNO
TRMFLG DATA 0 Flags
TRMBUF DATA $-$ Buffer address
TRMLRL DATA $-$ Logical record length
TRMCHC DATA $-$ Character count
*
* Message
*
STRING TEXT 'Hello world!'
BYTE >D,>A
STRLEN EQU $-STRING
EVEN
PAGE
*
* Main program entry
*
ENTRY MOVB R3,@TRMOPC Set open opcode in SCB
SVC @TRMSCB Open terminal
MOVB @TRMERR,R0 Check for error
JNE EXIT
MOVB R4,@TRMOPC Set write opcode
MOV R6,@TRMBUF Set buffer address
MOV R7,@TRMLRL Set logical record length
MOV R7,@TRMCHC and character count
SVC @TRMSCB Write message
MOVB @TRMERR,R0 Check for error
JNE CLOSE
CLOSE MOVB R5,@TRMOPC Set close opcode
SVC @TRMSCB Close terminal
EXIT SVC R2 Exit program
*
END
You can try out the above for yourself on a TI-990 simulator. Dave Pitts's sim990 simulates the TI-990 and includes software kits for native operating systems.
The following program is a standalone version that prints on the serial terminal connected to CRU address 0. It illustrates the CRU I/O and workspace linkage for the PRINT subroutine.
IDT 'HELLO'
TITL 'HELLO - hello world program'
*
R0 EQU 0
R1 EQU 1
R2 EQU 2
R3 EQU 3
R4 EQU 4
R5 EQU 5
R6 EQU 6
R7 EQU 7
R8 EQU 8
R9 EQU 9
R10 EQU 10
R11 EQU 11
R12 EQU 12
R13 EQU 13
R14 EQU 14
R15 EQU 15
*
* Terminal CRU bits
*
TRMCRU EQU >0 Terminal device address
XMIT EQU 8
DTR EQU 9
RTS EQU 10
WRQ EQU 11
RRQ EQU 12
NSF EQU 13
*
PAGE
*
* Main program entry
*
ENTRY LWPI WP Load our workspace pointer
BLWP @PRINT Call our print routine
DATA STRING
DATA STRLEN
IDLE
*
WP BSS 32 Main program workspace
*
* Message
*
STRING TEXT 'Hello world!'
BYTE >D,>A
STRLEN EQU $-STRING
EVEN
PAGE
*
* Print a message
*
PRINT DATA PRWS,PRENT
PRENT EQU $
MOV *R14+,R2 Get buffer address
MOV *R14+,R1 Get message length
SBO DTR Enable terminal ready
SBO RTS
PRI010 LDCR *R2+,8 Send out a character
TB WRQ Wait until done
JNE $-2
SBZ WRQ
DEC R1
JGT PRI010
RTWP
*
PRWS DATA 0,0,0,0,0,0,0,0
DATA 0,0,0,0,TRMCRU,0,0,0
*
END ENTRY
TI-990 models
The TI-990 processors fell into several natural groups depending on the original design upon which they are based and which I/O bus they used.All models supported the Communications Register Unit which is a serial bit addressable I/O bus. Also, supported on higher end models was the TILINE I/O bus which is similar to DEC's popular UNIBUS. The TILINE also supported a master/slave relationship that allowed multiple CPU boards in a common chassis with arbitration control.
TILINE/CRU models
The following models used the TILINE as their principal mass storage bus:- TI-990/5 — TMS-9900 microprocessor with 64K bytes of memory
- TI-990/10 — TTL processor with memory mapping support to 2M bytes of ECC memory
- TI-990/10A — TMS-99000 microprocessor with memory mapping support to 1M bytes of memory
- TI-990/12 — Schottky TTL processor with memory mapping to 2M bytes of ECC Memory, workspace caching, hardware floating point, extended mode instructions and writeable control store
CRU only models
- TI-990/4 — TMS-9900 microprocessor with 56K bytes of memory
- TI-990/9 — The original TTL implementation
Operating systems
From TI:
- TX990/TXDS
- DX10
- DNOS Distributed Network Operating System
- UCSD Pascal