# TI 99/4A HOME COMPUTER

SERVICING MANUAL

## COMPILED AND EDITED

BY

THE ENGINEERING STAFF

# OF

TEXAS INSTRUMENTS CONSUMER REPAIR CENTER

LUBBOCK TEXAS

THIRD REVISION, OCTOBER, 1983

# TI 99/4A HOME COMPUTER SERVICING MANUAL

COMPILED AND EDITED

.

BY

THE ENGINEERING STAFF

## OF

TEXAS INSTRUMENTS CONSUMER REPAIR CENTER

LUBBOCK TEXAS

THIRD REVISION, OCTOBER, 1983

# TABLE OF CONTENTS

.

| FAGE                                                                                                                                                                                                                                                                                                                                                                                        | #                                                                    |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|
| Introduction                                                                                                                                                                                                                                                                                                                                                                                | 01                                                                   |
| System Block Diagram                                                                                                                                                                                                                                                                                                                                                                        | 02                                                                   |
| Architectural Features                                                                                                                                                                                                                                                                                                                                                                      | 03                                                                   |
| TMS 9918 VDP<br>TMC 0430 Graphics ROM<br>TIM 9919 Sound Generator                                                                                                                                                                                                                                                                                                                           | 04<br>05<br>06                                                       |
| System Power Up                                                                                                                                                                                                                                                                                                                                                                             | 07                                                                   |
| Debug Check List                                                                                                                                                                                                                                                                                                                                                                            | 08                                                                   |
| Cassette Interface                                                                                                                                                                                                                                                                                                                                                                          | 09                                                                   |
| General Description                                                                                                                                                                                                                                                                                                                                                                         | 10                                                                   |
| Oscillator Circuit<br>CPU<br>Memory Selection Logic<br>Memory Map<br>ROM and RAM Memory<br>16 To 8 Bit Interfacing Circuit<br>Graphic Read Only Memory (GROM)<br>TMS 9901 Programmable System Interface<br>Video Display Processor<br>Sound Generation Controller<br>Keyboard & Remote Handheld Control Unit Interfacing<br>Cassette Interfacing Circuitry<br>I/O Bus<br>Power Supply Board | 13<br>15<br>34<br>37<br>39<br>48<br>44<br>73<br>78<br>78<br>79<br>81 |
| Trouble Shooting Guide                                                                                                                                                                                                                                                                                                                                                                      | 86                                                                   |
| I/O Port Connector                                                                                                                                                                                                                                                                                                                                                                          | 104                                                                  |
| GROM Fort Connector``                                                                                                                                                                                                                                                                                                                                                                       | 105                                                                  |
| Cassette I/O Fort                                                                                                                                                                                                                                                                                                                                                                           | 106                                                                  |
| RAM Trap                                                                                                                                                                                                                                                                                                                                                                                    | 107                                                                  |

-

FIGURE #

.

# DESCRIPTION

-

| 01     | System Block Diagram                                          | 02       |
|--------|---------------------------------------------------------------|----------|
| 02     | Clock Circuitry                                               | 14       |
| 03     | TMS 9900 Architecture                                         | 20       |
| 04     | TMS 9900 Pin Assignments And Functions                        | 21       |
| 05     | Memory Read Cycle Timing                                      | 25       |
| 06     | Memory Write Cycle Timing                                     | 26       |
| 07     | Memory Read Cycle Timing With One Wait State                  | 27       |
| 08     | Memory Write Cycle Timing With One Wait State                 | 28       |
| 09     | Direct Memory Access Timing                                   | 29       |
| 10     | CRU Interface Timing                                          | 30       |
| 11     | Memory Selection Logic                                        | 35       |
| 12     | ROM And RAM Memory                                            | 38       |
| 13     | 16 to 8 Bit Multiplexing Circuit                              | 41       |
| 14     | Control Signal Generation                                     | 47       |
| 15     | CPU Ready Generation                                          | 47       |
| 16     | WE Generation                                                 | <br>ДД   |
| 17     | External Cou Write Timing                                     | 45       |
| 10     | External CPU Pood Timing                                      | 40       |
| 10     | CROM Read Timina                                              | ~+0      |
| 17     | CROM Read Timing                                              | 4/       |
| 20     | GRUM Selection And Ready Logic                                | J∠<br>=→ |
| 21     | Ready (iming                                                  | ಂ        |
| 22     | IMS 9901 Fin Assignments And Functions                        | 5/       |
| 23.    | IMS 9901 1/U Interface Section Block Diagram                  | 60       |
| 24     | TMS 9901 Interupt Handling Logic                              | 61       |
| 25     | TMS 9901 Programmable System Interface                        | 62       |
| 26     | TMS 9901 Interval Timer Section                               | 63       |
| 27     | VDP Selection Logic                                           | 69       |
| 28     | Video Display Frocessor (VDP)                                 | 70       |
| 29     | TMS 9918 VDF Block Diagram                                    | 71       |
| 30     | TMS 9919 Sound Processor Selection Logic                      | 77       |
| 31     | LS 138                                                        | 110      |
| 32     | LS 194                                                        | 111      |
| 33     | LS 244                                                        | 112      |
| 34     | LS 245                                                        | 113      |
| 35     | TIM 9904 Four - Phase Clock Generator Driver                  | 114      |
| 36     | TIM 9904 Four - Phase Clock Generator Driver                  | 115      |
| 37     | LS 373                                                        | 116      |
| 38     | 4116 Dvnamic RAM                                              | 117      |
| 39     | MF 4732 ROMS                                                  | 119      |
| 40     | 6810 RAM                                                      | 120      |
| 41     | Pin Outs For TMS 9900, 1608-611, And 1614-616                 | 121      |
| 47     | Mainframe Board Lav-Out                                       | 1.00     |
| يوشد آ | Harnin ame board Lay bac tottettettettettettettettettettettet | کہ جکم ک |

# SCHEMATIC PACKAGE: 99/4

| FIGURE #   | DESCRIFTION                                | PAGE | Ξ # |
|------------|--------------------------------------------|------|-----|
| . –        |                                            |      |     |
| ن.4        | System Block Diagram                       | 1    | 123 |
| <b>4</b> 4 | 9900, RDM, RAM, And MUXing Circuit         |      | 124 |
| 45         | GROM And Audio Circuit                     |      | 125 |
| 46         | RAM And Video Circuit                      |      | 126 |
| 47         | 9901, Keyboard, Cassette, Joystick Circuit |      | 127 |
| 48         | I/O Buffers And I/O Port                   |      | 128 |
| 49         | Fower Supply                               |      | 129 |

# SCHEMATIC PACKAGE: 99/4A

| 50 | System Block Diagram 1                       | 30  |
|----|----------------------------------------------|-----|
| 51 | 9900, ROM, RAM, And MUXing Circuit 1         | .31 |
| 52 | GROM And Audio Circuit 1                     | .32 |
| 53 | RAM And Video Circuit 1                      | 33  |
| 54 | 9901, Keyboard, Cassette, Joystick Circuit 1 | 34  |
| 55 | I/O Buffers And I/O Port 1                   | .35 |

# LIST OF TABLES

| TABLE # | DESCRIPTION                                 | PAGE # |
|---------|---------------------------------------------|--------|
| 01      | CRU ASSIGNMENTS                             |        |
| 02      | 9900 INTERRUPTS                             | 24     |
| 03      | SUMMARY OF 9900 MICROPROCESSOR INSTRUCTIONS |        |
| 04      | SYSTEM MEMORY MAP                           |        |
| 05      | MEMORY MAPPED DEVICES                       | 36     |
| 06      | GROM I/O OPERATIONS                         |        |
| 07      | GROM MEMORY MAP                             | 51     |
| 08      | GROM INTERRUPT MAPPING                      | 58     |
| 09      | 9901 I/O MAPPING                            | 58     |
| 10      | FERIFHERAL ADDRESSES ON CRU BUS             |        |
| 11      | COLOR VECTOR RELATIONSHIPS                  |        |
| 12      | SCREEN DISPLAY PARAMETERS                   |        |
| 13      | VDF REGISTERS                               |        |
| 14      | ATTENUATION CONTROL                         |        |
| 15      | NOISE FEEDBACK CONTROL                      |        |
| 16      | NOISE GENERATOR FREQUENCY CONTROL           |        |
| 17      | REGISTER ADDRESS FIELD                      |        |
| 13      | CRU ALLOCATION                              | 81     |

iv

### INTRODUCTION

The TI 99/4 Home Computer was initially presented at the Consumer Electronics Show in June 1979 by Texas Instruments. The TI 99/4 is a TMS 9900-based microprocessor system. Fresently, the 99/4A mainframe is being manufactured by the Consumer Products Division of Texas Instruments Inc. in Lubbock, Texas.

The TI 99/4A has many key features. Some of these features, include 16-color graphics, music and sound over four octaves. The TI 99/4A also makes use of an expanded TI Basic. This feature plus the capability for up to 72K bytes of memory (16K RAM internal, 26K ROM, and up to 30K ROM interfaced via the Command Module peripherals) make the TI 99/4A Home Computer a very powerful tool. These key features and the general operation of the TI 99/4A will be presented in the following pages.

## SYSTEM BLOCK DIAGRAM:

The TI 99/4A Home Computer effectively combines each of the individual features of the unit into a complete and complex system. The basic blocks of the system include the CPU, sound generation, video display, I/O control, plus timing and control logic. These features are interfaced to produce the complete microprocessor system. The system block diagram of the TI 99/4A is shown in Figure 1, p. 2.

1



FIGURE 1 TI-99/4/ SYSTEM BLOCK DIAGRAM

2

# HOME COMPUTER KEY ARCHITECTURAL FEATURES

.

- 9900 CPU
- VIDED FROCESSOR WITH 10.74 MHz CRYSTAL OSCILLATOR FOR NTSC COMPOSITE VIDED GENERATION AND CONTROL OF GRAPHICS RAM
- 3 GRAPHICS ROMS ONBOARD WITH 6K BYTES EACH, EXPANSION PORT FOR SOFTWARE MODULES WITH UP TO FIVE 6K X 8 GROMS AND 8K ROM OR RAM
- 48 KEY KEYBOARD
- TV INTERFACE VIA VIDEO MODULATOR
- FERIPHERAL CONNECTORS WITH CRU AND 8 BIT MEMORY INTERFACE

.

● 1200 BAUD HOME CASSETTE INTERFACE

## HOME COMPUTER TMS 9918 VIDED DISPLAY PROCESSOR KEY FEATURES

REFRESH THE TV SCREEN AT 60 Hz WITHOUT INTERFACE FOR COMPOSITE NTSC VIDEO OUTPUT

. .

- 24 LINES OF 32 CHARACTERS WITH 8 X 8 DOT RESOLUTION
- 32 MOVABLE CHARACTERS WITH MAGNIFICATION
- 24 LINES OF 40 CHARACTERS WITH 6 X 8 DOT RESOLUTION
- 48 LINES OF 64 INDEFENDENT SPOTS
- EXTERNAL VIDEO INPUT WITH SYNC
- PROVIDE 8 COLORS WITH 2 LUMINOUS LEVELS EACH
- PROVIDE 8 SETS OF COLOR SELECT REGISTERS TO PROVIDE SEPARATE COLOR FOR ONES AND ZEROS
- ADDRESS 4-16K BYTES OF RAM FOR CPU OR DISPLAY
- SINGLE 5 VOLT FOWER SUPPLY
- 10.74 MHz ONBOARD CRYSTAL OSCILLATOR
- GROM CLOCK
- 40 PIN PLASTIC PACKAGE

## HOME COMPUTER TMC 0430 GRAPHICS ROM KEY FEATURES

- 6144 BYTES MASK PROGRAMMABLE ROM
- 16 BIT ADDRESS REGISTER WITH INCREMENTER
- CHIP SELECT FROM 3 MOST SIGNIFICANT ADDRESS BITS
- INSTRUCTION DECODE FOR FOUR OPERATIONS
  - READ BYTE AND INCREMENT
  - WRITE HIGH ADDRESS BYTE AND TRANSFER HIGH TO LOW
  - READ LOW ADDRESS BYTE

-SPARE TO WRITE RAM OR PROM

- LOW COST F CHANNEL MOS
- 9us CYCLE TIME
- +5, -5 POWER SUPPLIES WITH TTL INTERFACE
- 447.5 KHz CLOCK INPUT
- 15 FIN FACKAGE

.

# HOME COMPUTER TIM 9919 SOUND GENERATOR KEY FEATURES

3 VOICES WITH 4 OCTAVE MUSICAL RESOLUTION 15 BIT PROGRAMMABLE NOISE SHIFT REGISTER 100 mW AUDIO DRIVE WITH 30DB CONTROL IN 2DB STEPS 8 BIT CPU INTERFACE 5V POWER SUPPLY

I<sup>4</sup>L TECHNOLOGY

16 PIN PACKAGE

## SYSTEM FOWER UP

POWER IS TURNED ON:

- 9900 CPU RESETS AND ADDRESSES LOW ROM LOCATIONS
- 9900 INITIALIZES
- 9900 SETS UP WORKSPACE REGISTERS IN 6810 RAM
- 9900 BEGINS READING FROM GROMS
- 9900 ENTERS TIME DELAY LOOF TO ALLOW STABILIZATION 🛱 SEC
- 9919 SOUND CHIP IS TURNED OFF
- 9918 VDP IS INITIALIZED
- 4116 RAM IS CLEARED REQUIRES APPROXIMATELY 1 SEC
- FRONT FANEL DISFLAY IS WRITTEN INTO VDF
- 9919 SOUND CHIP EMITS BEEP
- 9900 CPU ENTERS KEYBOARD SCAN ROUTINE

SYSTEM IS NOW READY FOR USER INPUT

## ITEMS TO CHECK DURING DEBUG

- 1 CHECK IF FRONT PANEL IS UP "TI LOGO"
- 2 CHECK +5, +12 VOLT LEVELS THROUGHOUT BOARDS
- 3 CHECK IF READY PIN 62 OF 9900 IS LOCKED UP
- 4 CHECK THE FOUR 12 VOLT CLOCKS FROM 74362 TO 9900
- 5 CHECK

GROM SELECT FIN 10 0430 GROM READY FIN 15 0430 GROM CLOCK FIN 13 0430

- 6 CHECK PIN 38 OF 9918 FOR 3.579548 MHz CLOCK NOTE: SYSTEM WILL RUN WITH CLOCK FROM 3.579520 MHz TO 3.579548 MHz
- 7 CHECK VDP (9918) READ PIN 15 9918 WRITE PIN 14 9918
- 8 CHECK DATA OUT OF 4116 RAM FIN 14
- 9 CHECK COMPOSITE VIDEO FROM PIN CONNECTOR

### HOME COMPUTER CASSETTE INTERFACE

- 1. Operates with byte/manchester encoding format.
- 2. Utilizes redundancy to gain increased reliability.
- 3. Uses wave shaping on input and output to increase reliability.
- 4. Has two motor control circuits which allow computer to control decks.
- 5. Has capability of reading from one deck and writing to another, under computer control.
- 6. The interface is software intensive and relies on 9901 internal timer for it's timing.

PROBLEM AREA OF CASSETTE INTERFACE

- Reliable recovery of data is dependent on recorder used during save.
- Reliability is directly proportional to frequency response of cassette deck.
- Reliability can be observed by looking for the "eye" or "jitter" phenomenon with an oscilloscope.
  - A. Present reliability is dependent on amount of jitter. If jitter is less than 60 ms cassette should work.
- Cassette is also adversely affected by speed changes.
  - A. Motor control circuit can under special circumstances cause this.

The following paragraphs provide a description of the 99/4A system hardware, the VDP chip (TMS 9918), the sound chip (TMS 9919), the GROM (TMC 0430), the associated timing diagrams, the cassette interface circuitry and power supply.

99/4 SYSTEM HARDWARE

The 99/4 has been built around the TMS 9900 microprocessor. Figure 1, shows a block diagram of the system. In this description the logic of the 99/4 is grouped into the following functional sections.

- Clock generator/driver
- Microprocessor unit
- Memory selection logic
- System ROM & RAM
- 16 to 8 bit interfacing circuit
- Timing and control logic
- GROM memory
- TMS 9901 programmable system interface
- TMS 9918 video display processor
- TMS 9919 sound generator
- Keyboard, remote handheld unit
- Cassette interfacing circuit
- I/O port
- Fower supply
- European power supply
- Audio board

The purpose and composition of these functional sections is to provide an overview of the 99/4A system with a detailed description in the succeeding paragraphs.

- The clock generator/driver provides 4 non-overlapping clock signals for the TMS 9900 microprocessor and also internal latch which is used on the reset circuitry.
- The microprocessor unit with the TMS 9900 handles all the processing as required by the on board software as well as the off board software (DSR's and command modules), interrupts, and power up initialization.
- The memory address/decode logic provides enabling signals to the various RAM's, ROM's, GROM's and interface circuit.
- System RAM consists of 256 bytes static RAM used as a scratch pad memory for all system operations. The system ROM consists of 8K bytes of the following system programs.
  - The GFL interpreter.
  - Floating point routines.
  - String conversation routines.
  - Cassette interfacing and I/O programs.
  - Basic programs.
- The 16 to 8 bit interfacing circuit enable the 99/4 to access 8 bit devices by multiplexing and demultiplexing the 16 bit data bus of the TMS 9900.
- Timing and control logic provides the timing and enables signals for the 16 to 8 bit interfacing circuit. It also handles the READY and WE signal for memory operations.
- The TMS 9901 I/O controller is the interface used by the keyboard scanning circuit and the cassette interfacing circuit. It also handles interrupts and has an on-chip timer.
- GROM memory consists of 18K bytes of graphics program. (Graphics is the intermediate language used in the 99/4A) It contains the following system routines:

| GROM | 0 | : | - Monitor routines                               |
|------|---|---|--------------------------------------------------|
|      |   |   | - First part of the equation calculator.         |
|      |   |   | - The cassette-device subroutine contain ROM.    |
| GROM | 1 | : | - The editor                                     |
|      |   |   | - The prescan routine for basic.                 |
|      |   |   | - The first part of the basic executing program. |
| GROM | 2 | : | - The file management programs.                  |
|      |   |   | - The second part of the basic executing program |
|      |   |   | - The second part of the equation calculator.    |

GROM memory is expandable up to a limit of 48K through the grom I/O port. The GROM port enables the user to run preprogrammed software in up to 5 GROM's in a software module. This module may also contain in ROM processing for generating the composite video signal. A part of the 16K byte uses RAM during the power-up sequence.

The TMS 9919 sound generator is a one chip device capable of generating 3 tones and noise programmable by the user.

The keyboard interface is using the TMS 9901 I/O chip. The keyboard scanning is using the multiplexing technique.

The I/O port provides the capability to the 99/4 to access the ROM in the various peripherals containing the device service routines (DSR's) and it takes care of the data exchange.

The audio board houses an audio amplifier to drive the 8 ohm in the European version of the 99/4. Volume control is by a slide pot.

## OSCILLATOR CIRCUIT

# GENERAL DESCRIPTION

The TMS 9900 microprocessor, as used in the TI 99/4, uses four non overlapping clock signals generated by a 74LS362 clock generator/ driver. These four clock signals (01, 02, 03 and 04) are available at TTL level. A timing diagram for the clock signals is given in figure 35, p.114. As can be seen from the internal schematics of the 74LS362 figure 35, there is also a D type latch available. This latch, clocked by 03, is in the reset circuitry.

HARDWARE DESCRIPTION (SEE FIGURE 2, F.14.)

#### FOWER CONNECTIONS

------

Power connection points are pin 10 for ground, pin 13 for the  $\pm 12v$  and pin 20 for the  $\pm 5$  volt supply. L603, L604, C604, C605 and C607 are used for decoupling of noise generated by the 74LS362.

#### POWER UP

Pin 17, connected to the 5 volt power supply by serieg resestor R604 enables the clock outputs.

#### RESONATOR PART

A third overtone, 48MHz crystal, connected between pin 18 and 19 determines the clock frequency. The tank circuit with L602 and L603 connected between FINS 1 and 2 selects the third overtone. Some units may use a 12 MHZ crystal with tank components to select the primary frequency.

#### CLOCK SIGNALS

Fin 8, 9, 11 and 12 are the four 12 volt clock outputs for the TMS 9900. The four series resistors R601, R602 and R603 minimize over and undershoot. The inverted clock signals on pin 6, 7, 14 and 15 are used internally in the 99/4 for timing purposes.

#### RESET

Reset is accomplished during power-up and when a solid state software command module is inserted. C606 will be slowly charged by resistor R605 after applying power to the console. Thus for a short period the D input of pin 5 of the 74LS362 is low. The 74LS362 clocks this zero binary value to the reset out of pin 4. This signal resets the TMS 9900 until a binary 1 value is sensed on pin 5. When the system is switched off, R606 discharges C606, thus enabling a new reset. When a solid state software command module is inserted, the reset line is connected to -5 volt. C606 is then partly discharged by C506, thus dropping the voltage at pin 5 for a short time to the binary low level, generating a reset. When the solid state software command module is removed, resistor R514 will discharge C506 to enable a new reset.



.



,

. . .

| R514<br>R600<br>R601<br>R602<br>R603<br>R604<br>R605 | 47K<br>22<br>22<br>22<br>22<br>1K<br>12K | C506 154 F<br>C603 224 F<br>C604 .14 F<br>C605 104 F<br>C606 154 F<br>C606 154 F<br>C607 1 nF<br>Y600 XTAL 48MHz<br>U601 74LS362 |
|------------------------------------------------------|------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| R606                                                 | 150K                                     | 0001 /40000                                                                                                                      |

#### CENTRAL PROCESSING UNIT

# GENERAL DESCRIPTION

THE 99/4A Home Computer use the Texas Instruments TMS 9900 microprocessor. It provides the system with a 15 bit address and 16 bit data bus for communication with external memory. It also has input and output pins for serial in and output, interrupt handling and memory control (see figures 3 and 4, p.20-23).

### MEMORY INTERFACING

The TMS 9900 interfaces with memory by means of a 16 bit data bus (DD-D15), the 15 bit address bus (AD-A14) and the following control signals.

- MEMEN MEMORY ENABLE. When active (low), MEMEN indicates that the address bus contains a memory address.
- WE WRITE ENABLE. When active (low), WE indicates that memory write data is available from the TMS 9900 to be written into memory.
- DBIN DATA BUS IN. When active (high), READY indicates that memory will be ready to read or write <u>during</u> the next clock cycle. When not ready is indicated during a memory operation, the TMS 9900 suspends further operation (e.g. enters a wait state) until READY becomes active again, after which the memory read/write cycle is completed. This signal enables the use of slow memory devices with the TMS 9900.
- WAIT WAIT. When active (high), WAIT indicates that the TMS 9900 has entered a wait state because of a not-ready condition from memory.

Timing diagrams for read and write cycles, with and without wait states, are given in Figures 5-8, p.25-28.

### DIRECT MEMORY ACCESS

Ferforming memory access without interference of the TMS 9900 is called direct memory access (DMA). For this purpose the following control lines are available.

HOLD When active (low), HOLD indicates to the processor that an external controller desires to use address, data and memory control signals. The TMS 9900 enters the hold state following a hold signal when it has completed its present memory cycle. The processor then places the address and data buses in the high-impedance state along with MEMEN, WE and DBIN and responds with a hold ackowledge signal (HOLDA). When HOLD is removed, the processor returns to normal operation.

HOLDA (HOLD ACKNOWLEDGE) When active (high), HOLDA indicates that the processor is in the hold state and that the outputs (MEMEN, WE and DBIN) are in the high inpedance state thus making it possible for an external device to use the buses and access memory.

The timing diagram for direct memory access is given if Figure 9,p.29.

IN AND OUTFUT (1/0)

The TMS 9900 has two possibilities for communicating with external devices:

A. Addressing the device as memory.

B. Using the communication resister unit (CRU).

The CRU makes it possible to communicate with extenal devices with fewer lines.Only A3 through A14, CRUIN, CRUOUT and CRUCLK are used. The CRU I/O bus makes it also possible to address bits or words

#### OUTPUT

Output with the CRU interface is performed as follows: The processor addresses the bit to be set. This address is decoded and enables a latch to the data present on the CRUOUT lines on CRUCLK.

#### INFUT

Input is performed only with the address bus and CRUIN. Again the processor addresses the bit to be read. The system hardware decodes the bit address on A3 through A14 and enables the addressed bit to put its value on the CRUIN line. The bit is then fetched by the TMS 9900.

#### TIMING DIAGRAM

A timing diagram of CRU operations is given in figure 10,p30. The TI 99/4 home computer uses both ways of I/O to communicate with internal and external devices.

### INTERRUFT HANDLING

Interrupt processing logic on the TMS 9900 uses the following inputs.

INTREQ INTERRUFT REQUEST. When active (low) INTREQ indicates that an external interrupt is requested. If INTREQ is active, the processor loads the data on the interrupt-code input lines ICO through IC3 into the internal interrupt-code storge resister. This code is compared to the interrupt mask bits of the enabled interrupt level, the TMS 9900 interrupt sequences is initiated. If the comparison fails, the processor ignores the request. INTREQ should remain active and the processor will continue to sample ICO through IC3 until the program enables a sufficiently low priority to accept the requested interrupt.

ICO INTERRUPT CODES. ICO is the most sighificant bit of the IC1 interrupt code, which is sampled when INTREQ is active. IC2 When ICO through IC3 are LLLH, the highest external IC3 priority interrupt and when HHHH the lowest prority is being requested.

In this system, ICO,IC's and IC2 are tied to VSS,and IC3 is tied to VCC, thus if INTRED is active, it is always considered the highest priority.

TIMING SIGNAL The TMS 9900 has an additional timing signal IAQ which becomes high during any memory cycle when the TMS 9900 is acquiring an instruction. This signal can be used for timing purposes. SUPPLY VOLTAGES The TMS 9900 requires 3 voltages with respect to ground. VBB. - 5 volt supply voltage + 5 volt supply voltage VCC +12 volt supply voltage VDD VSS. system ground CLOCK INPUTS Four clock signals, 01, 02, 03 and 04, have to be provided on the four clock input pins for internal timing of the TMS 9900. Note that these inputs require a 12 volt swing. SYSTEM START UP The following signals can be used for system start up. RESET When active (low), RESET resets the processor. When RESET is released the TMS 9900 starts execution of its programs with the first memory address fetched from memory location 0002. LOAD When active (low), the processor starts execution of its programs on the address in memory location FFFE. During a reset or load, the microprocessor also fetches the workspace pointer. This is the starting address of a memory field of 16 words in RAM memory which is used as a register field. During reset the workspace pointer is fetched from address 0000, during load from address FFFC. HARDWARE DESCRIFTION A drawing of the connections to the TMS 9900 as used in the 99/4 is given in Figure 4,p.21.

The following list describes the connections in more detail.

FOWER CONNECTIONS

- + 5 volt. The +5 volt power supply is connected to FIN 2 and 59 of the TMS 9900. L600, C600 and C611 are acting as a filter to reduce system noise on FIN2 and C603 is used for the same purpose on FIN 59.
- +12 volt. The +12 volt power supply is connected to PIN 27 L601 and C612 are acting as a filter to reduce noise.
- 5 volt. The -5 volt power supply is connected to PIN 1 with C602 for decoupling.

Pin connections 26 and 40 are for ground. CLOCK INPUTS Clock inputs 01, 02, 03 and 04 are input on pins 8, 9, 25 and 28 respectively. ADDRESS BUS The 99/4 uses the address bus internally without further buffering, except for A14, which is used on the GROMs (see I/O bus description). DATA BUS Internal ROM and RAM uses the data bus without buffering. Τo connect the data bus to internal 8 bit devices and for in and output, a special 16 to 8 bit interfacing circuit is used. CRU BUS CRUOUT, CRUI and CRUCLK are used internally without buffering. INTERRUPT HANDLING Interrupt vector pins 33 through 36 are preset to code LLLH, the highest external priority interrupt. So the 99/4 knows only de interrupt level. The INTREQ line is connected to the TMS 9901. which handles the interrupts. RESET The system resets during power up or when a solid state software command module is inserted. This is done by connecting RESET pin 6 to pin 4 of the system clock generator (U601). LOAD The load function or pin 4 is connected to the I/O Fort via resistor R523. WRITE ENABLE The WE function or pin 61 is used by fast system RAM without buffering and is modified by timing and control for other devices. IAQ/HOLDA The instruction aquisition signal on pin 7 and the hold acknowledge signal on pin 5 are combined on OR-gate U605 to generate a combined signal. MEMORY ENABLE (MEMEN) This signal is buffered by OR gate U605 for further use in and outside the 99/4. R607 is used as a pull up resistor to +5 volt to assure that memory is disabled during power up. DBIN The DBIN signal on pin 29 is buffered twice by inverting gates U602 for use within the 99/4 system. READY/HOLD

GROUND

READY and HOLD on pins 62 and 64 are combined to form one signal.

A study of 9900's internal structure is useful when trying to understand the operation of the IC. The architecture of the 9900 microprocessor is shown in the diagram of figure 3,p.20. This shows the internal features within the CPU.

- These features include:
  - \* The ALU
  - \* 3 Multiplexer buses
  - \* Control Logic and Control ROM
  - \* Internal Registers: Memory address register, shift register, status register, source data register, shift counter, workspace register, instruction register, and auxillary register T1 and T2.

The ALU (Arithmetic Logic Unit) is a 16-bit, parallel logic network used in the execution of the 9900's instructions. The unit performs arithmetic functions, log, and comparisons. The multiplexer buses are used in the transfer of flow and data in the CFU. The control circuitry provides the signals necessary for correct gating.

The control logic and control ROM provide the necessary signals for the correct sequencing of operation of the CPU's instructions. This is accomplished with the aid of the input control signals and master timing. Among the internal registers there are three which are key architectural features of the CPU. These registers are the workspace pointer that contains the location of the first word in the workspace. The program counter contains the address for the next word which is to be used in the execution of an instruction. The status register determines if the conditions necessary for an instruction execution have been met. This is done by the setting of flags.

In the operation of the 9900, sixty-nine instruction words can be used. A list of the 9900's instruction set can be found in Table 3,p.31. These instructions are used to perform arithmetic operations, logic, comparisons, and manipulation operations on data. They are also used for the loading and storing of data within the CPU's internal registers. Data transfer between the external memory system and external devices is also made possible with the instructions via the CRU. Instructions are also used as control functions within the CPU.

The external memory used with the TMS 9900 in the TI 99/4 and TI 99/4A consists of two TMS 4732's and two MCM 6810F's. The TMS 4732's are 4K X 8bit ROMS and are addressed via lines A3-A14 of the address bus. However, one of the 4732's uses the D1-D7 lines on the data bus while the other uses data lines D8-D15, thus combining the two 6810's are combined to form a 128 X16 bit RAM. One slight difference from the 4732's is that the 6810's are addressed by address lines A8-A14.

The 9900 uses three control signals during operation of the external memory read and write to control the use of the address and data busses. These signals are DBIN, -MEMEN, and -WE. During memory read, DBIN and -MEMEN are active, while -WE is not. The active signals allow an output onto the address bus indicating the desired memory location to be read. DBIN is active (high) when the 9900 has disabled its output buffers and is used in the system to enable data input to the processor.



ARCHITECTURE

figure 3

.

•

.

#### 2.8 TMS 9900 PIN DESCRIPTION

Table 2 defines the TMS 9900 pin assignments and describes the function of each pin.

| TABLE 2                 |                 |
|-------------------------|-----------------|
| TMS 9900 PIN ASSIGNMENT | S AND FUNCTIONS |

| SIGNATURE | PIN   | 1/0 | DESCRIPTION                                  |             | TMS         | 9900 PIN ASSIGNM | ENTS                     |          |
|-----------|-------|-----|----------------------------------------------|-------------|-------------|------------------|--------------------------|----------|
|           |       |     | ADDRESS BUS                                  | Vac         | 1:5         |                  | E: 64                    | HOLD     |
| AQ (MSB)  | 24    | ουτ | A0 through A14 comprise the address but.     | Vcc         | 2           | 2                | E 63                     | MEMEN    |
| A1        | 23    | OUT | This 3-state bus provides the memory-        | WAIT        | 3           |                  | 62                       | READY    |
| A2        | 22    | οστ | address vector to the external-memory        | LOAD        | 4           |                  | H 61                     | WE       |
| A3        | 21    | ουτ | system when MEMEN is active and I/O-bit      | HOLDA       | 5 🖒         |                  | <b>1</b> 60              | CRUCLK   |
| A4        | 20    | 00T | addresses and external-instruction addresses | RESET       | •           |                  | 59                       | Vcc      |
| AS        | 19    | സ   | to the I/O system when MEMEN is inactive.    | DAI         | <b>"</b> ロ  |                  | <b>₽</b> 35€             | NC       |
| A6        | 18    | 007 | The address bus assumes the high-impedance   | <b>ø</b> 1  | •           |                  | <b>F</b> 57              | NC       |
| A7        | 17    | τυο | state when HOLDA is active.                  | ¢2          | ㅋ티          |                  | <b>F</b> <sup>56</sup>   | D15      |
| A8        | 16    | DUT |                                              | A14         | 10 5        |                  | <b>F</b> <sup>3 55</sup> | D14      |
| A9        | 15    | ουτ |                                              | A13         | " =         |                  | Est                      | D13      |
| A10       | 14    | OUT |                                              | A12         |             |                  | 53                       | D12      |
| A11       | 13    | OUT |                                              | A11         | 35          | •                | H <sup>32</sup>          | 011      |
| A12       | 12    | 001 |                                              | A 10        | : H         |                  | E.                       | ~        |
| A13       |       |     |                                              | A¥          |             | 1                | <b>H</b> 30              | 09<br>Ce |
| A14 (LSB) | 10    | 001 |                                              |             |             |                  | H.                       | 07       |
|           |       |     | DATA BIS                                     | A6          |             |                  | ×.                       | Dis .    |
| DO (MSR)  | 41    | 1/0 | D0 showsh 015 comprise the bidirectional     | 45          |             |                  | F                        | 06       |
| 01        | 47    | 1/0 | Jemie data but. This but transfer memory     |             | 20 H        |                  | H                        | 04       |
| 07        | 41    | 1/0 | data to (when writing) and from (when        | A3          | 7 2         |                  | H                        | 03       |
| 01        | 44    | 1/0 | reacting) the external-memory system when    | A7          | - 7         |                  | Ha                       | 07       |
| D4        | 45    | 1/0 | MEMEN is active. The data bus assumes the    | A1          | 25          |                  | C 42                     | D1       |
| DS        | 46    | 1/0 | high-impedance state when HOLDA is           | AO          | 24 5        |                  | E: 41                    | DO       |
| D6        | 47    | 1/0 | active.                                      | 64          | <b>¤</b>    |                  | 40                       | Vss      |
| 07        | 48    | 1/0 |                                              | Vss         | 28 🖾        |                  | C 39                     | NC       |
| 08        | 49    | 1/0 | · ·                                          | VDD         | 27 🖾        |                  | <b>43</b> 38             | NC       |
| 09        | 50    | 1/0 |                                              | \$3         | 28 🛱        |                  | 37                       | NC       |
| D10       | 51    | 1/0 |                                              | DBIN        | 29 🗘        |                  | <b>⇒</b>                 | 100      |
| 011       | 52    | 1/0 |                                              | CRUOUT      | 30 🛱        |                  | 1 35                     | 1C1      |
| D12       | 53    | 1/0 |                                              | CRUIN       | 31 🟳        |                  | 1234                     | 102      |
| D13       | 54    | 1/0 |                                              | INTREO      | ) X 🗘       | <u> </u>         | 33                       | B        |
| D14       | 55    | 1/0 |                                              |             |             |                  |                          |          |
| D15 (LSB) | 56    | 1/0 |                                              |             |             |                  |                          |          |
|           |       |     |                                              | NC - No in  | ternal co   | nnection         |                          |          |
|           |       | 1   | POWER SUPPLIES                               |             |             |                  |                          |          |
| Ves       | 1     |     | Supply voltage (-5 V NOM)                    |             |             |                  |                          |          |
| Vcc       | 2,59  | 1   | Supply voltage (5 V NOM), Pins 2 and 59 m    | nust de con | nected in   | peranel,         |                          |          |
| Y00       | 27    |     | Supply voltage (12 V NOM)                    |             |             |                  |                          |          |
| V55       | 26,40 |     | Ground reference, Pins 26 and 40 must be o   | connected + | n parailei. |                  |                          |          |
|           |       |     | CLOCKS                                       |             |             |                  |                          |          |
| al        | 8     | 111 | Phase-1 clock                                |             |             |                  |                          |          |
| <br>      | 9     | IN  | Phase-2 clock                                |             |             |                  |                          |          |
| 43<br>43  | 28    | IN  | Phase-3 clock                                |             |             |                  |                          |          |
| 64.       | 25    | IN  | Phase-4 clock                                |             |             |                  |                          |          |
|           | 1     | 1   |                                              |             |             |                  |                          |          |

Fig. 4

# TMS 9900 ARCHITECTURE

.

## Product Data Book

----

| TABLE 2 (CONTINUED)                  |                      |                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|--------------------------------------|----------------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| SIGNATURE                            | PIN                  | 1/0                  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| DBIN                                 | 29                   | ουτ                  | BUS CONTROL<br>Data bus in, When active (high), DBIN indicates that the TMS 9900 has disabled its output buffers to<br>allow the memory to place memory-read data on the data bus during MEMEN. DBIN remains low in<br>all other cases except when HOLDA is active.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| MEMEN                                | ଣ                    | τυο                  | Memory enable. When active (low), MEMEN indicates that the address bus contains a memory address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| WE                                   | 61                   | ουτ                  | Write enable, When active (low), WE indicates that memory-write data is available from the TMS 9900 to be written into memory.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| CRUCLK                               | 60                   | ουτ                  | CRU'clock. When active (high), CRUCLK indicates that external interface logic should tample the<br>output data on CRUOUT or should decode external instructions on A0 through A2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| CRUIN                                | 31                   | IN                   | CRU data in, CRUIN, normally driven by 3-state or open-collector devices, receives input data from<br>external interface logic. When the processor executes a STCR or TB instruction, it samples CRUIN for<br>the level of the CRU input bit specified by the address bus (A3 through A14).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| CRUOUT                               | 30                   | ол                   | CRU data out. Serial I/O data appears on the CRUOUT line when an LDCR, SBZ, or SBO instruction<br>is executed. The data on CRUOUT should be sampled by external I/Q interface logic when CRUCLK<br>goes active (high).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| INTREO                               | 32                   | IN                   | INTERRUPT CONTROL<br>Interrupt request. When active (low), INTREQ indicates that an external interrupt is requested. If<br>INTREQ is active, the processor loads the data on the interrupt-code-input lines ICD through IC3 into<br>the internal interrupt-code-storage register. The code is compared to the interrupt mask bits of the<br>status register. If equal or higher priority than the enabled interrupt level (interrupt code equal or less<br>then status register bits 12 through 15) the TMS 9900 interrupt sequence is initiated. If the<br>comparison fails, the processor ignores the request. INTREQ should remain active and the processor<br>will continue to sample IC0 through IC3 until the program enables a sufficiently low priority to accept<br>the request interrupt. |  |  |
| ICO (MSB)<br>IC1<br>IC2<br>IC3 (LSB) | 36<br>35<br>34<br>33 | 1N<br>1N<br>(N<br>1N | Interrupt codes, ICO is the MSB of the interrupt code, which is sampled when INTREQ is active. When ICO through ICO are LLLH, the highest external-priority interrupt is being requested and when HMMH, the lowest-priority interrupt is being requested.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| HOLD                                 | 64                   | IN                   | MEMORY CONTROL<br>Hold. When active (low), $\overline{HOLD}$ indicates to the processor that an external controller (e.g., DMA<br>device) desires to utilize the address and data buses to transfer data to or from memory. The<br>TMS 9900 enters the hold state following a hold signal when it has completed its present memory<br>cycle." The processor then places the address and data buses in the high-impedance state (along with<br>WE, MEMEN, and DBIN) and responds with a hold-ecknowledge signal (HOLDA). When $\overline{HOLD}$ is<br>removed, the processor returns to normal operation.                                                                                                                                                                                            |  |  |
| HOLDA                                | 5                    | τυο                  | Hold acknowledge. When active (high), HOLDA indicates that the processor is in the hold state and the address and data buses and memory control outputs (WE, MEMEN, and DBIN) are in the high-impedance state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| READY                                | 62                   | IN                   | Ready. When active (high), READY indicates that memory will be ready to read or write during the<br>next clock cycle. When not-ready is indicated during a memory operation, the TMS 9900 enters a wait<br>state and suspends internal operation until the memory systems indicate ready.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| WAIT                                 | 3                    | OUT                  | Wait, When active (high), WAIT indicates that the TMS 9900 has entered a wait state because of a not-ready condition from memory.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |

\*If the cycle following the present memory cycle is also a memory cycle, it, too, is completed pefore the TMS9900 enters the hold state. The meximum number of consecutive memory cycles is three.

Fig. 4 (continued)

| Product Da | ta Boo | *   | TMS 9900<br>ARCHITECTURE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|--------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |        |     | TABLE 2 (CONCLUDED)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| SIGNATURE  | PIN    | 1/0 | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| QVI        | 2      | INO | TIMING AND CONTROL<br>finitruction acquisition. FAG is active [high] during any memory cycle when the TMS 8900 is acquiring an<br>Instruction. FAQ can be used to detect illegal op codes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| LOAD       | •      | Z   | Load. When active flow!, $\overline{LOAD}$ causes the TMS 9900 to execute a nonmarkable interrupt with memory address FFFC to containing the trap vector (WP and PC). The load sequence begins after the instruction being executed is completed. $\overline{LOAD}$ will also terminate an idle state. If $\overline{LOAD}$ is active during the time $\overline{RESET}$ is released, then the $\overline{LOAD}$ trap will occur after the $\overline{RESET}$ is necessed, then the $\overline{LOAD}$ trap will occur after the $\overline{RESET}$ is instruction being a completed. $\overline{LOAD}$ trap will occur after the $\overline{RESET}$ is necessed, then the $\overline{LOAD}$ trap will occur after the $\overline{RESET}$ is necessed. |
| HESET      | 6      | Z   | can be used to implement cold start ROM loaders. Additionally, front-panel routines can be implemented<br>using CRU bits as front-panel-interface signals and software-control routines to control the panel<br>operations.<br>Result. When active flow!, RESET causes the processor to be reset and inhibits WE and CRUCLK. When<br>RESET is released, the TMS 9900 then initiates a level-servo interrupt sequence that ecquires WP and PC<br>from focusions 00000 and 0002, and status resister bits to zero, and state accounted. RESET will also                                                                                                                                                                                                 |
|            |        |     | terminate en idle state. RESET must be held active for a minimum of three clock cycles.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

Fig. 4 (continued)



FIGURE 2 - MEMORY MAP

Three internal registers are accessible to the user. The program counter (PC) contains the address of the instruction following the current instruction being executed. This address is referenced by the processor to fetch the next instruction from memory and is then automatically incremented. The status register (ST) contains the present state of the processor and will be further defined in Section 3.4. The workspace pointer (WP) contains the address of the first word in the currently active set of workspace registers.

A workspace-register file occupies 16 contiguous memory words in the general memory area (see Figure 2). Each workspace register may hold data or addresses and function as operand registers, accumulators, address registers, or

Drivers are deactivated to prevent the input data from conflicting with output data. Memory write makes use of -MEMEN also -WE both active, and DBIN deactivated. Under these conditions the 9900 outputs on the address and data buses and holds these outputs for the duration required by RAM.

### CRU ALLOCATION

Of the available 4K of CRU bits, the first 1K (addresses 0000 07FE) are used internally in the Home Computer. The second 1K (addresses 0800-OFFE) are reserved for future use. The last 2K (addresses 1000-1FFFE) are reserved for the peripherals to be plugged in the I/O port. A block of 128 CRU bits is assigned to each peripheral as listed below.

## TABLE 1 CRU ASSIGNMENTS

------

CRU

| ADDRESSES | A3 | A4    | A5  | A6 | A7    | USE              |
|-----------|----|-------|-----|----|-------|------------------|
| 0000-0FFE | 0  | <br>X | X   | X  | <br>X | <br>INTERNAL USE |
| 1000-10FE | 1  | Ō     | 0   | Ō  | Ō     | RESERVED         |
| 1100-11FE | 1  | Ō     | 0   | 0  | 1     | DISK CONTROLLER  |
| 1200-12FE | 1  | Ō     | 0   | 1  | Ō     | RESERVED         |
| 1300-13FE | 1  | 0     | 0   | 1  | 1     | PRIMARY RS232    |
| 1400-14FE | 1  | 0     | · 1 | Ō  | 0     | RESERVED         |
| 1500-15FE | 1  | 0     | 1   | Ò  | 1     | SECONDARY RS232  |
| 1600-16FE | 1  | Ō     | 1   | 1  | 0     | RESERVED         |
| 1700-17FE | 1  | Ō     | 1   | 1  | 1     | RESERVED         |
| 1800-18FE | 1  | 1     | 0   | Ō  | Ο.    | THERMAL PRINTER  |
| 1900-19EE | 1  | 1     | х   | Х  | х     | FUTURE EXPANSION |
| 1F00-1FFE | 1  | 1     | 1   | 1  | 1     | F-CODE           |

#### INTERRUPT HANDLING

------

The interrupt available on the I/O port is one of the maskable interrupts of the TMS 9901 Programmable Systems Interface.

# TABLE 2 9900 INTERRUPTS

| INTERRUPT<br>LEVEL    |        | VECTOR LOC.<br>(MEMORY ADDR.<br>IN HEX) | CFU<br>FIN            | DEVICE<br>ASSIGNMENT            |
|-----------------------|--------|-----------------------------------------|-----------------------|---------------------------------|
| (HIGHEST<br>FRIORITY) | 0<br>1 | 0000<br>FFFC<br>0004                    | RESET<br>LOAD<br>INT1 | RESET<br>LOAD<br>EXT DEV (9901) |

Lower priority CPU interrupt are not used. The additional interrupts available are implemented on the 9901.





Fig. 5

25



-

Figure 6. Memory Write Cycle Timing.

Fig. 6

26





Fig. 7




Fig. 8



Figure 9. 'Direct Memory Access Timing.



29





.

Fig. 10

30

TABLE 3. SUMMARY OF 9900 MICROPROCESSOR INSTRUCTIONS

MNEMONIC INSTRUCTION CODE DESCRIPTION

| A    | ADD WORDS                         |
|------|-----------------------------------|
| AB   | ADD BYTES                         |
| ABS  | ABSOLUTE VALUE                    |
| AI   | ADD IMMEDIATE                     |
| ANDI | AND IMMEDIATE                     |
| в    | BRANCH                            |
| BL   | BRANCH AND LINK                   |
| BLWF | BRANCH AND LOAD WORKSPACE FOINTER |
| С    | COMPARE WORDS                     |
| СВ   | COMPARE BYTES                     |
| CI   | COMPARE IMMEDIATE                 |
| CKOF | CLOCK OFF (CONTROL INSTRUCTION)   |
| CKON | CLOCK ON (CONTROL INSTRUCTION)    |
| CLR  | CLEAR                             |
| COC  | COMFARE ONES CORRESPONDING        |
| CZC  | COMFARE ZEROES CORRESFONDING      |
| DEC  | DECREMENT                         |
| DECT | DECREMENT BY TWO                  |
| DIV  | DIVIDE                            |
| IDLE | IDLE (CONTROL INSTRUCTION)        |
| INC  | INCREMENT                         |
| INCT | INCREMENT BY TWO                  |
| INV  | INVERT                            |

## SUMMARY OF 9900 MICROPROCESSOR INSTRUCTIONS (CONTINUED)

.

MNEMONIC INSTRUCTION CODE DESCRIPTION

| JEQ   | JUMP IF EQUAL TO                         |
|-------|------------------------------------------|
| JGT   | JUMF IF GREATER THAN                     |
| јн    | JUMP IF GREATER THAN (LOGIC)             |
| JHE   | JUMF IF GREATER THAN OR EQUAL TO (LOGIC) |
| JL    | JUMP IS LESS THAN                        |
| JLE   | JUMP IF LESS THAN OR EQUAL TO (LOGIC)    |
| JLT   | JUMF IF LESS THAN                        |
| JMF   | UNCONDITIONAL JUMF                       |
| JNC   | JUMF IF NO CARRY                         |
| JNE   | JUMP IF NOT EQUAL                        |
| JND   | JUMF IF NO OVERFLOW                      |
| JOC   | JUMF ON CARRY                            |
| JOF   | JUMF ON ODD FARITY                       |
| LDCR  | LOAD CRU                                 |
| LI    | LOAD IMMEDIATE                           |
| LIMI  | LOAD INTERRUPT MASK IMMEDIATE            |
| LREX  | RESTART (CONTROL INSTRUCTION)            |
| LWFI  | LOAD WORKSPACE POINTER IMMEDIATE         |
| MOV   | MOVE (WORD)                              |
| MOVB  | MOVE BYTE                                |
| MFY   | MULTIFLY                                 |
| NEG   | NEGATIVE                                 |
| ORI   | OR IMMEDIATE                             |
| RESET | RESET(CONTROL INSTRUCTION)               |

SUMMARY OF 9900 MICROPROCESSOR INSTRUCTIONS (CONTINUED)

÷

MNEMONIC INSTRUCTION CODE DESCRIPTION

| RTWP | RETURN WITH WORKSPACE POINTER     |
|------|-----------------------------------|
| S    | SUBTRACT WORDS                    |
| SB   | SUBTRACT BYTES                    |
| SBO  | SET BIT TO LOGIC ONE              |
| SBZ  | SET BIT TO LOGIC ZERO             |
| SETO | SET TO ONE                        |
| SLA  | SHIFT LEFT ARITHMETIC             |
| SOC  | SET ONE CORRESPONDING             |
| SOCB | SET ONES CORRESPONDING            |
| SRA  | SHIFT RIGHT ARITHMETIC            |
| SRC  | SHIFT RIGHT CIRCULAR              |
| SRL  | SHIFT RIGHT LOGICAL               |
| STCR | STORE CRU                         |
| STST | STORE STATUS                      |
| STWP | STORE WORKSPACE POINTER           |
| SWPB | SWAP BYTES                        |
| SZC  | SET TO ZERDES CORRESPONDING       |
| SZCB | SET TO ZEROES CORRESPONDING BYTES |
| ТВ   | TEST BIT                          |
| X    | EXECUTE                           |
| XOF  | EXTENDED OPERATION                |
| XOR  | EXCLUSIVE OR                      |

33

#### MEMORY SELECTION LOGIC

## GENERAL DESCRIPTION

The memory selection logic decodes the more significant address lines for selecting fast ROM and RAM memory. Also the output of the decoder is used for a second decoder, which selects internal devices such as VDP, sound etc...

# HARDWARE DESCRIPTION

The schematics of the memory selection logic with a memory map is given in Figure 11, p.35. When MEMEN is active, U504 (74LS138) decodes the three most significant address lines A0 through A3, dividing the address space in the following 8 blocks of 8 bytes.

#### BLOCK O

Memory Block O (>0000->1FFF) is used to select the system read only memory (ROM).

### BLOCK 1

Memory Block 1 (>2000->3FFF) is reserved for memory expansion.

## BLOCK 2

Memory Block 2 (>4000->4FFF) is used to select read only memory in external devices, such as RS232 interface. The ROM in these devices contains the device service routine (MBE).

#### BLOCK 3

Memory Block 3 (>6000->7FFF) is used for the optional read only memory in solid state software command modules (RDMG).

#### BLOCK 4

Memory Block 4 (>8000->9FFF) is used divided in several parts. Memory locations >8000 to >83FF are used for the fast system read-and-write memory. This further decoding of the address space is done in OR-gates US07. This part of the circuitry also generates the RAMBLK signed, which is used to select the TMS 9901 programmable system interface. Furthermore the MB4 signal is used to select a second 74LS138 which divides memory block 4 in more parts.

#### BLOCK 5, 6 AND 7

These blocks are used along with Block 1 for memory expansion.

#### START SIGNAL

By combining the CSRAM and ROMEN signals , together with MEMEN in NAND-gate U606 and OR-gate U605, the START signal is developed. This signal is used in the 16 to 8 bit interfacing circuit.



| SIGNAL | ADDRESSED MEMORY LOCATION | USE                        |
|--------|---------------------------|----------------------------|
| ROMEN  | 0000 - 1FFF               | SYSTEM ROM SELECT          |
| MBE    | 4000 - 5FFF               | EXT. DEVICE ROM SELECT     |
| ROMG   | 6000 - 7FFF               | SOFTWARE MODULE ROM SELECT |
| MB4    | 8000 - 9FFF               | MEMORY BLOCK 4             |

Fig. 11

#### MEMORY ALLOCATION

\_\_\_\_

The memory address space is broken into 8 blocks of 8K bytes of memory. The third block (addresses 4000 - 5FFF) is predecoded and made available at the I/O port for the peripherals. The second sixth, seventh and eighth blocks (addresses 2000-3FFF and A000 - FFFF) are available for further expansion. For the speech module, (addresses 90XX - 94XX), a predecoded line is available at the I/O port.

.

.

-

TABLE 4 SYSTEM MEMORY MAP

HEX ADDRESS

| 0    |   | 1FFF | Console ROM Space                                        |  |  |  |  |  |  |  |  |
|------|---|------|----------------------------------------------------------|--|--|--|--|--|--|--|--|
| 2000 | - | SFFF | Memory Expansion                                         |  |  |  |  |  |  |  |  |
| 4000 |   | SFFF | Peripheral expansion (predecoded to I/O Connector)       |  |  |  |  |  |  |  |  |
| 6000 | - | 7FFF | Game cartridge ROM/RAM (predecoded to GROM Connector)    |  |  |  |  |  |  |  |  |
| 8000 | - | 9FFF | Microprocessor RAM,, VDP, GROM, SOUND and SPEECH select. |  |  |  |  |  |  |  |  |
| 000A |   | BFFF | Memory Expansion                                         |  |  |  |  |  |  |  |  |
| C000 | - | DFFF | Memory Expansion                                         |  |  |  |  |  |  |  |  |
| E000 |   | FFFF | Memory Expansion                                         |  |  |  |  |  |  |  |  |

TABLE 5 MEMORY MAPPED DEVICES

| ADDRESSES | AO | A1   | A2 | A3 | A4 | AS | A14 | A15 | USE                         |
|-----------|----|------|----|----|----|----|-----|-----|-----------------------------|
| 8000      | 1  | 0    | 0  | 0  | 0  | 0  | 0   | 0   | Internal RAM<br>(8300-83EE) |
| 8400      | 1  | Ō    | Ō  | 0  | Ō  | 1  | 0   | Ō   | Sound                       |
| 8800      | 1  | Ō    | 0  | 0  | 1  | 0  | Ō   | 0   | VDF Read Data               |
| 8802      | 1  | Ō    | Ō  | 0  | 1  | 0  | 1   | 0   | VDF Read Status             |
| 8000      | 1  | 0    | 0  | 0  | 1  | 1  | 0   | 0   | VDF Write Data              |
| 8002      | 1  | Ō    | Ō  | 0  | 1  | 1  | 1   | 0   | VDP Write                   |
|           |    |      |    |    |    |    |     |     | Address                     |
| 9000      | 1  | 0    | Ō  | 1  | O. | 0  | 0   | 0   | Speech Read                 |
| 9400      | 1  | 0    | 0  | 1  | 0  | 1  | Ō   | Ō   | Speech Write                |
| 9800      | 1  | 0    | Ō  | 1  | 1  | Ō  | Ō   | Ō   | GROM Read Data              |
| 9802      | 1  | • .O | Ō  | 1  | 1  | Ō  | 1   | 0   | GROM Data                   |
|           |    |      |    |    |    |    |     |     | Address                     |
| 9000      | 1  | Ō    | Ō  | 1  | 1  | 1  | Ō   | 0   | GROM Write Data             |
| 9002      | 1  | 0    | 0  | 1  | 1  | 1  | 1   | 0   | GROM Write<br>Address       |

#### ROM & RAM MEMORY

## GENERAL DESCRIPTION

The 99/4A Home Computer uses 8K bytes of read only memory for execution of fast system routines. It also has 256 bytes of random access memory which is used as a scratch pad memory.

#### READ ONLY MEMORY

The 99/4A uses the TMS 4732 as a read-only memory. This device contains 32K bits of read-only memory. It is housed in a 24 pin dual in line package and uses a single 5 volt supply voltage. 12 address lines are used to select 4K bytes of 8 bits. The device uses two chip select inputs, which both have to be active (low) to select the device.

#### READ-AND-WRITE MEMORY

The 99/4A uses the MCM 6810 as random access memory. The MCM 6810 is housed on a 24 pin dual in line package and uses a single 5 volt supply voltage. 7 address lines are used to select 128 fields of 8 bits. 6 pins are available for device selection, of which two have to be low and four have to be high to select the RAM. Another pin (R/W) is provided to distinguish between writing and reading of data.

HARDWARE DESCRIPTION

Hardware connections to ROM and RAM memory are given in figure 12,p.38.

#### RAM MEMORY

Two RAMS (U608 & U609) are connected in parallel to generate a 16 bit data bus, as is required by the TMS 9900. The devices are selected by the RAMCS signal, generated by the memory selection logic. Distinction between reading and writing is made by connecting the WE signal of the TMS 9900 to the R/W PIN 16. Address lines A8 through A14 are used to select the proper memory locations.

#### ROM MEMORY

Both ROMS are connected in parallel to generate the required 16 bit data bus. The ROMS are selected by the ROMEN signal, generated by the memory selection logic. This signal is applied on pin 20. Address lines A3 through A14 are used to select the proper memory locations.





Fig. 12

## 16 TO 8 BIT INTERFACING CIRCUIT.

#### GENERAL DESCRIPTION

#### 

The 16 to 8 bit interfacing circuit is used to interface 8 bit devices such as Video Display Processor (VDP). The sound chip, graphics-read-only memory (GROM) and external 8 bit peripherals to the 16 bit data bus of the TMS 9900. It does so by successively placing the least significant and most significant byte of a word on the 8 bit system data bus during a write operation. During a read operation adjacent bytes are placed in the least significant and most significant byte of the 16 bit word. To enable 8 bit devices to destinguish between the bytes, an additional address line A15 is generated. The interfacing circuit also performs the synchronization between devices connected to the 8 bit system data bus and the TMS 9900 by generating adequate timing of WE and READY signals. A schematic of the interfacing circuit is given in figure 13, p. 41.

### HARDWARE DESCRIPTION

The hardware description is divided in the following parts:

- A. Description of the 16 to 8 bit multiplexing circuit.
- B. Generation of the control signals for the multiplexing ... circuit.
- C. READY/HOLD generation.
- D. WE generation.

#### A. 16 TO 8 BIT MULTIPLEXING CIRCUIT

An overview of the hardware used to interface the 16 to 8 bit data uses is given in figure 13, p. 41. During a write operation the data on the 16 bit bus is gated to the 8 bit system bus by enabling U616 and U614 in succession. During a read operation the least significant byte on the 8 bit data bus is stored in the 8 bit latch U615. Then the most significant byte is gated to the 16 bit data bus by enabling bidirectional buffer U614 and the total word is fetched by the TMS 9900. The DIOG and DBIN on U614, DING and A15 on U615 and the DOG on U616 are used for enabling IC's and for determining the direction to the data flow if no interfacing occurs, the 16 bit data bus is kept floating to allow the TMS 9900 to access ROM or RAM memory.

### B. CONTROL SIGNAL GENERATION

Control signals for the multiplexing circuit are generated by the circuit in figure 14, p. 42. U613 is a 4 bit shift register the outputs of which are used for timing purposes. When the START signal is high, pin 2 of U604 is low. This pin, connected to pin 1 of U613, sets all the outputs of the shift register to a binary zero. Since the START signal is also connected to pin 10, the shift register is disabled. Control signal generation is started when START becomes low, pin 10 which also becomes low selects the shift right mode of shift register U613. Shift operation is then started as soon as pin 9 of U613 becomes high, depending on the system ready status. When the shift operation has begun shift right input on pin 2. On every rising flank of Q1 (pin 11) the contents of the shift registers are shifted one position, giving

timing signals on the outputs QA, QB, and QC (see figures 17-18, p.45-46). These outputs are used for generating the control signals in NAND-gates U603 and U606. Both DBIN and DBIN are used for selecting the direction of the data flow. CSVDPR disables U614 if a read from the video display processor occurs, because the VDP data bus is directly connected to D1-D7 of the TMS 9900.

C. READY GENERATION

The READY generation circuit as shown in figure 15, p.43 has two operating modes. In the normal mode the system ready signals is input on pin 12 of U607. The pull-up resistor R508 assures that under normal circumstances the READY signal is true. Slow devices can add wait states by pulling pin 12 of U607 to ground. The READY signal is sampled on 02 and available on pin 9 of U607.

THERE ARE NOW TWO POSSIBILITIES:

#### ROM OR RAM IS SELECTED

In this case shift register U613 is not enabled and the READY signal is gated directly via U603 and U602 to the READY/HOLD input of the TMS 9900. Note that in this case pin 12 of U603 has to be high.

#### EXTERNAL READY TIMING

If other devices then ROM or RAM are selected, the 16 to 8 bit interfacing circuit will be used. This means that the TMS 9900 has to be put in a WAIT state until two bytes of data are written or read by the interfacing circuit. This is accomplished by decoding the QA and QC outputs of the shift register in NAND-gates U612 and U603 to provide a low READY signal until both bytes are processed by the interfacing circuit. If during this operation a device generates a not READY, the shift register will stop its operation until ready becomes high again. Timing diagrams for the READY signal can be seen in figures 7-8, p.27-28.

### WE GENERATION

The WE circuit as given in figure 16,p44 generates the WE signals when writing data to an external device. In that case WE of the system has to be low every time a byte of information is transferred. To accomplish this, outputs QB, on pin 14 and QC on pin 13 of U613 are used to set and preset flip flop U607 on pin 2 and 4. In this way two periods of 2 clock cycles long for which WE is low are generated on pin 3 of U606. Q4, which is in agreement with TMS 9900 timing. WE is only gated to external devices when a memory write is accomplishesd by combining the WE of the TMS 9900 after inverting in U602 with the WE of the interfacing circuit. The total signal is then available of pin 3



Fig. 13





Fig. 14









Fig. 16



EXTERNAL CPU . WRITE TIMING

Fig. 17



Fig. 18



**GROM READ TIMING** 

Fig. 19

### GRAPHIC READ ONLY MEMORY

## GENERAL DESCRIPTION

The TMC 0430 GROM is a P-channel read only memory containing 6144 8-bit bytes. The circuit has an on chip autoincrementing address counter which selects one of the 6144 memory bytes.

#### FUNCTIONAL DESCRIPTION

-------

## CFU INTERFACE

The GROM interfaces to the CPU through the parallel data bus and the memory control lines as shown in figure 52, p.132. The CPU interface consists of 8 data I/O lines (DO-D7), chip enable (CE), READY, and 2 mode control lines (MO, M1). The GROM also requires a nominal 500 KHz clock input (OSC).

#### GROM FAGING

The GROM has a 16-bit address register of which the lower 13-bits are used to address the 6144-byte ROM matrix. The most significant field is used to select one of eight GROM pages. Each GROM has a fixed 3-bit page number which is determined during manufacture. The GROM compares this number with the address register page select field. If a match occurs, then the GROM is the "selected page" or "current page". The GROM data bus is placed into the output mode during a read data operation only if the GROM is the current page. The other GROM functions are not affected by the page select field. The page select field permits up to eight GROMs to be used in parallel. Each GROM is tied to the same chip enable, memory control, and data lines as the other GROMs. Since the page select field does not affect the data register or address register operations, all parallel GROMs are synchronized following initialization. However, since only one GROM is the current page, only one GROM outputs data on the data bus during a read data operation. If no GROM is selected (the address register page field does not match the page number of any GROM), then no GROM is placed into the output mode during a read data operation. During a read address operation, all GROMs output the address byte. Since all GROMs are synchronized following initialization no data bus conflict occurs.

#### ADDRESS REGISTER AUTOINCREMENTATION

The address counter is autoincremented following a read data, write data, or a pair of consecutive write address operations. When the current address is 8191, the next autoincrement cycle will result in a zero address value. The page select field is not affected by the autoincrement.

When the value of the address register lower 13-bit field is greater that 6143, the GROM will continue to fetch data from the 6144 byte array. This condition should be avoided in order to prevent invalid data fetches and transfers.

#### INITIALIZATION

During the power up sequence, the microprocessor should execute a "dummy" read data operation. This will guarantee that a newly powered up GROM will not respond to the first write address operation as if the were the second write address operation. The

microprocessor should then initialize the GROM address registers with two consecutive write-address operations.

## READY

The GROM ready line is normally low and is high only when the GROM has an active CE and has read in the contents of the data bus during a write operation or has placed data on the bus during a read operation. The READY line control is independent of the page select. Typical READY line timing is shown in figure 21, p. 53.

#### ACCESS DELAY

The GROM requires that a second I/O operation not occur before it has completed the first operation. Consequently, CE must remain high at least 2.5 GROM clock cycles following the trailing edge of the last I/O operation. For a minimal 500 kHz OSC input, the minimal required delay between the rising edge of CE and the next falling edge is 5 microseconds.

#### I/O OPERATIONS

When CE becomes active (low), the mode lines determine which one of four GROM I/O operations is to occur as shown in Table 6.

TABLE & GROM I/O OPERATIONS

MODE

- MO M1 I/O OPERATION
- \_\_ \_\_ \_\_\_\_

- 0 0 WRITE DATA The write data operation is included for use in future read/write versions of the GROM. The write data operation does not result in a data transfer to the TMC 0430 GROM. The address register is then autoincremented. The addressed ROM byte is fetched and placed into the GROM data register.
- 0 1 READ DATA The read data operation transfers the data byte in the data register to the CPU if the GROM is the current page. The address register is then autointremented. The addressed ROM byte is fetched and placed we into the GROM data register.
- 1 0 WRITE ADDRESS The write address operation transfers the data byte on the GROM data I/O bus to the least significant byte (LSB) of the GROM address register. The old address register (LSB) is transferred to the address register most significant byte (MSB). Two consecutive write address operations cause the addressed ROM byte to be fetched and placed into the GROM data register; the address register is then autoincremented. A write address operation immediately following a read data, read address, or write data operation does not result in a data fetch and address autoincrementation.
- 1 1 READ ADDRESS The read address operation transfers the MSB of the address register to the CFU if the GROM is the current page. The address register LSB is automatically transferred to the MSB.

It should be noted that the MO line controls whether the data or address register is to be affected and the M1 line controls whether the operation is an input or output cycle.

## HARDWARE DESCRIPTION

The 99/4 has three internal GROMs (TMC 0430) and the possibility to add 5 more external GROMs via the GROM port. All GROMs are connected in parallel as can be seen in figure 52, p.132.

#### GROM CLOCK

The clock signals for the GROMs are derived from the TMS 9918 video display processor. The clock cycle time is 2.24 usec. A 1K ohm pull-up resistor is used to ensure proper functioning of the P-channel device with TTL logic.

#### DATA BUS INTERFACING

All GROMs are connected in parallel to the 8 bit data bus.

#### MODE CONTROL

The type of operation performed by the GROM is determined by connections DBIN to M1 and address line A14 to M0. Thus a read operation is performed when DBIN is high and a write operation when DBIN is low. Address line A14 distinguishes between data and address operations.

#### GROM SELECT

GROM select is performed by the circuit in figure 20, p 52. When MEMEN is low, U504 decodes address lines AO, A1 and A2. Decoder output Y4 is used to select a second 3 to 8 decoder U505. This device is enabled when A15 and one or both signals DBIN and A5 are low. Decoding of address lines A3, A4 and A5 are then used to select the GROMs by "ANDing" outputs Y6 and Y7 by means of the NAND U506 and inverter U508.

#### GROM READY

The GROM ready signal is connected to the READY/HOLD via U508 and U506. U508 inverts the GROM READY signal. This signal is then combined in NAND-GATE U506 with the GROM select signal to get the appropriate signal for the system READY/HOLD line.

#### MEMORY MAP

Table 7 shows the memory map for the successive GROM instructions.

## TABLE 7 GROM MEMORY MAP

| ADDRESS  | TYPE OF INSTRUCTION |
|----------|---------------------|
|          |                     |
|          |                     |
| 9800<br> | READ GROM DATA      |
| 9802     | READ GROM ADDRESS   |
| 9000     | WRITE GROM DATA     |
| 9002     | WRITE GROM ADDRESS  |

As can be seen, address A14 distinguishes between an address and data instruction. Distinction between read and write instructions is made by DBIN and the different addresses. This is done because when writing data or address information, the 9900uP executes a dummy read which would otherwise influence the address counter in the GROM.



Figure 20. GROM Selection and Ready Logic.

Fig. 20



DATA BUS

\* t  $\overline{CE}$  to READY time  $\frac{1}{2}$  6 µsec



### TMS 9901 FROGRAMMABLE SYSTEM INTERFACE

## GENERAL DESCRIPTION

The TMS 9901 is a programmable system interface (PSI), which can be used for input, output and interrupt priority handling. It also features an on chip programmable interval timer. The TMS 9901 is used for keyboard, remote handheld control unit, cassette recorder interfacing and VDP interrupt handling in the 99/4A system.

The TMS 9901 PSI interfaces to the CPU through the Communication Register Unit (CRU) and the interrupt control lines. The TMS 9901 occupies 32 bits of CRU input and output and space. The five least significant bits of the address bus are connected to the PSI to address one of the 32 CRU bits of the TMS 9901. The most significant bits of the address bus are decoded on CRU cycles to select the PSI by taking its chip enable (CE) line active (low).

Interrupt inputs to the TMS 9901 PSI are sychronized with Q3, inverted, and then ANDed with the appropriate mask bit. Once every Q3 clock time, the prioritizer looks at the 15 interrupt input AND gates & generates the interrupt control code. The interrupt control code and the interrupt request line constitute the interrupt interface to the CPU.

After reset all I/O ports are programmed as inputs. By writing to any I/O port, that port will be programmed as an output port until another reset occurs, either software or hardware. Data at the input pins are buffered on the TMS 9901. Data to the output ports in latched and then buffered on-chip by the PSI's MOS to TTL buffers.

The interval timer on the TMS 9901 is accessed by writing a one to select bit zero (control bit) which puts the FSI CRU interface in the clock mode. Once in the clock mode the 114 bit clock contents can be read or written. Writing to the clock register will reinitialize the clock and cause it to start decrementing. When the clock counts to zero, it will cause interrupt and reload to its initial value. Reading the clock contents permits the user to see the derementer contents at the point in time just before entering the clock mode. The clock read register is not updated when the FSI is in the clock mode. A block diagram of the TMS 9901 FSI is given in figure 25, p.62.

#### CRU INTERFACE

The CPU communicates with the TMS 9901 PSI via the CRU. The TMS 9901 occupies 32 bits in CRU read space and 32 bits in CRU write space. The CRU interface consist of 5 address select lines (SO-S4), chip enable (CE), and three CRU lines (CRUIN, CRUOUT, CRUCLK). The select lines (SO-S4) are connected to the five least significant bits of the address bus (A10-A14). Chip enable (CE) is generated by decoding the most significant bits of the address bus on CRU cycles: When CE goes active (low), the five selected lines point to the CRU bit being accessed. Whin CE is inactive (high), the FSI's CRU interface is disabled. In case of a write operation, the TMS 9901 strokes data off the CRUOUT line with CRUCLK. For read operation, the data is sent to the CFU on the CRUIN line.

## INTERRUPT INTERFACE

A block diagram of the interrupt control section is shown in figure 24, p. 61. The interrupt inputs (6 dedicated (INT1-INT6), and 9 programmable) are sampled on the falling edge of Q3 and latched onto the chip for one Q3 inverted (interrupts are active low) and ANDed with its respective mask bit (mask=1, interrupt enabled). On the rising edge of Q3, the prioritizer and encoder senses the masked interrupts and produces a four-bit prioritized code and INTREQ are latched off chip with a SYNCLATCH on the falling edge of the next Q3. which ensures proper synchronization to the processor. The interrupt mask bits on the TMS 9901 PSI are individually set or reset under software control. Any unused interrupt line should have its associated mask disabled to avoid false interrupt: to do this, the control bit (CRU bit zero), is first set to a zero for interrupt mode operation. Writing to TMS 9901 CRU bits 1-15 indicates the status of the respective interrupt inputs; thus, the designer can employ the unused (disabled) interrupt input lines as data inputs (true data in).

#### INFUT/OUT INTERFACE

A block diagram of the TMS 9901 I/O interface is shown in figure 23, p.60. Up to 16 individually controlled I/O ports are available (seven dedicated, FO-F6, and nine programmable) and as discussed above, the unused dedicated interrupt lines also can be used as input lines (true data in). Thus the TMS 9901 can be configured to have more than 16 inputs. RST1 or RST2 (command bit ) is executed. An output port can be read and indicates the present state of the pin. A pin programmed to the output mode cannot be used as an input pin: applying an input current to an output pin may cause damage to the TMS 9901. The TMS 9901 outputs are latched and buffered on chip, and inputs are buffered onto the chip. The output buffers are MOS-TO TTL buffers and can drive two standard TTL loads.

## PROGRAMMABLE PORTS

A total of nine pins on the TMS 9901 are user programmable as either I/O ports or interrupts. These pins will assume all characteristics of the type pin they are programmed to be. Any pin which is not being used for interrupts should have the appropriate interrupt mask disabled (mask=0) to avoid erroneous interrupts to the CPU. To program one of the pins as an interrupt, its interrupt mask simply is enabled and the line may be used as if it were one of the dedicated interrupt lines. To program a pin as an I/O port, disable the interrupt mask and use that pin as if it were one of the dedicated I/O ports.

#### INTERVAL TIMER

Figure 26, p.63 is a block diagram of the TMS 9901 interval timer section. The clock consists of a 14 bit counter that decrements at a rate of (Q3)/64 (at 3MHz this results in a maximum interval 349 milliseconds with a resolution of 21.3 microseconds). The clock can be used as either an interval timer or an event timer. To access the clock, select bit zero (control bit) must be set to a one. The clock is enabled to cause interrupts by writing a nonzero value to it and is then disabled from interrupting by writing zero to it or by an RST1. The clock starts operating at no more than two 03 times after it is loaded. When the clock decrementer is running, it will decrement down to zero and will then be reloaded from the clock register and decrementing will start again. (The zero state is counted as any other decrementer state). The decrementer always runs, but it will not issue interrupts until enabled; of course, the contents of the not enabled clock read registers are meaningless.

#### FOWER UP

During hardware reset, RST1 must be active (low) for a minimum of two clock cycles to force the TMS 9901 into a known state. RST1 will disable all interrupts, disable the clock, program all I/O ports to the input mode, and force ICO-IC3 to all zero's with INTREO held high. The system software must enable the appropriate interrupts, program the clock, and configure the I/O ports as required. After initial power-up the TMS 9901 is accessed only as needed to service the clock, enable (or disable) interrupts, or read (write) data to the I/O ports. The I/O ports can be configured by use of the RST2 software reset command bit.

HARDWARE DESCRIPTION

Connections to the TMS 9901 as used on the 99/4A are given in figure 22,p.57. The TMS 9901 is reset during power up by using the buffered reset signal of the TMS 9900. The TMS 9901 enabled by the RAMBLK signal (see memory selection part, figure 11 p.35). When enabled, the 9901 communicates with the TMS 9900 through the CRUIN, CRUOUT and CRUCLK lines. The CRU bits are selected by decoding A10 through A14. Connections with the devices which interface to the TMS 9901 are discussed in other sections.

55

## TMS 9901 JL, NL PROGRAMMABLE SYSTEMS INTERFACE

## 2.7 Pin Descriptions

Table 4 defines the TMS 9901 pin assignments and describes the function of each pin.

| SIGNATURE  | PIN | 1/0 | DESCRIPTION                                                                                                                                                                                                         |                     |             |            |                                                                                             |               |          |  |  |  |  |
|------------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-------------|------------|---------------------------------------------------------------------------------------------|---------------|----------|--|--|--|--|
| INTREQ     | 11  | ουτ | INTERRUPT Request. When active (low)<br>INTRED indicates that an enabled interrupt<br>has been received. INTRED will stay active                                                                                    | RSTI<br>CRUQUT      | ŗġ          | U          | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>- | Vcc<br>so     |          |  |  |  |  |
|            |     |     | untii all enabled interrupt inputs are re-<br>moved.                                                                                                                                                                | CRUCLK<br>CRUIN     | יע<br>גע    |            | U 39                                                                                        | P0<br>P1      |          |  |  |  |  |
| ICO (MSB)  | 15  | OUT | Interrupt Code lines, ICO-IC3 output the                                                                                                                                                                            | 25                  | • ប្រ       |            | 2 38                                                                                        | \$1           |          |  |  |  |  |
| IC1        | 14  | ουτ | binary code corresponding to the highest                                                                                                                                                                            | INT6                | • <u>H</u>  |            | H =                                                                                         | \$2           |          |  |  |  |  |
| 1C2        | 13  | ουτ | priority enabled interrupt. If no enabled                                                                                                                                                                           | 1875                | <u>'   </u> |            | H                                                                                           | IN T 7/P 15   |          |  |  |  |  |
| IC3 (LSB)  | 12  | ουτ | interrupts are active ICO-IC3 = (1,1,1,1).                                                                                                                                                                          | 11174               | 1           |            | 10 10                                                                                       |               |          |  |  |  |  |
| CE         | 5   | IN  | Chip Enable, When active (low) data may be                                                                                                                                                                          |                     | 1           |            | H.                                                                                          | 10/11/0/017   |          |  |  |  |  |
|            |     |     | transferred through the CRU interface to                                                                                                                                                                            | INTREO I            | Ĭ           |            | ii ii                                                                                       | INT 11/P11    |          |  |  |  |  |
|            |     |     | the CPU, CE has no effect on the interrupt                                                                                                                                                                          | IC3 1               | z ŭ         |            | 6.5                                                                                         | INT12/#10     |          |  |  |  |  |
|            |     |     | control section.                                                                                                                                                                                                    | 102 1               | ۵đ          |            | 5 28                                                                                        | INT 13/P9     |          |  |  |  |  |
| SO         | 39  | IN  | Address select lines. The data bit being                                                                                                                                                                            | IC1 1               | ∎ Ū         |            | 5 27                                                                                        | INT 14/PB     |          |  |  |  |  |
| 51         | 36  | IN  | accessed by the CRU interface is specified                                                                                                                                                                          | IC0 1               | s 🖞 👘       |            | 0 28                                                                                        | P7            |          |  |  |  |  |
| 52         | 35  |     | by the 5-bit code appearing on 50-54.                                                                                                                                                                               | V55 1               | • 0         |            | D 25                                                                                        | 53            |          |  |  |  |  |
| 3.J<br>5.4 | 23  | IN  |                                                                                                                                                                                                                     | INT1 1              | " (]        |            | D 24                                                                                        | 54            |          |  |  |  |  |
|            |     |     | CRII days in the CRIII Days receiving by                                                                                                                                                                            | INTZ 1              | • []        |            | 2 23                                                                                        | 1NT 15/P7     |          |  |  |  |  |
| CAUIN      | •   | 001 | SO SA is transmitted to the CP11 by CR11N                                                                                                                                                                           | P6 1                | •• []       |            | 2 22                                                                                        | P3            |          |  |  |  |  |
|            |     |     |                                                                                                                                                                                                                     | PS 2                | × لا        |            | 21                                                                                          | P4            |          |  |  |  |  |
|            |     |     | impedance state.                                                                                                                                                                                                    |                     |             |            |                                                                                             |               |          |  |  |  |  |
| CRUOUT     | 2   | IN  | CRU data out (from CPU), When CE is active, o                                                                                                                                                                       | lata present on t   | ne CRU      | 10UT in    | out will                                                                                    | be sampled    | during   |  |  |  |  |
|            |     |     | CRUCLK and written into the command bit specifi                                                                                                                                                                     | ed by \$0-\$4.      |             |            |                                                                                             |               |          |  |  |  |  |
| CRUCLK     | 3   | IN  | CRU Clock (from CPU), CRUCLK specifies that va                                                                                                                                                                      | lid data is present | on the      | CHUOU.     | T line.                                                                                     |               |          |  |  |  |  |
| ASTI       | 1   | IN  | Power Up Reset. When active flow) RST1 resets all interrupt masks to "0", resets EO = EC3 + $(0, 0, 0, 0)$ , INTERQ + 1 disables the clock, and programs all EO ports to inputs. RST1 has a Schmitt-triger input to |                     |             |            |                                                                                             |               |          |  |  |  |  |
|            |     |     | allow implementation with an RC circuit as shown in Figure 7                                                                                                                                                        |                     |             |            |                                                                                             |               |          |  |  |  |  |
| Vcc .      | 40  |     | Supply Voltage. +5 V nominal.                                                                                                                                                                                       |                     |             |            |                                                                                             |               |          |  |  |  |  |
| ∨ss        | 16  |     | Ground Reference                                                                                                                                                                                                    |                     |             |            |                                                                                             |               |          |  |  |  |  |
| ō          | 10  | IN  | System clock (03 in TMS 9900 system, CKOUT in                                                                                                                                                                       | TMS 9980 system     | 1).         |            |                                                                                             |               |          |  |  |  |  |
| INT 1      | 17  | IN  | h                                                                                                                                                                                                                   |                     |             |            |                                                                                             |               |          |  |  |  |  |
| INT2       | 18  | IN  | Group 1, interrupt inputs.                                                                                                                                                                                          |                     |             |            |                                                                                             |               |          |  |  |  |  |
| INT 3      | 9   | IN  | When active (Low) the signal is ANDed with its ci                                                                                                                                                                   | orresponding        |             |            |                                                                                             |               |          |  |  |  |  |
| NT4        | 8   | IN  | mask bit and if enabled sent to the interrupt contr                                                                                                                                                                 | ol section.         |             |            |                                                                                             |               |          |  |  |  |  |
| INTS       | 7   | IN  | INT1 has highest priority.                                                                                                                                                                                          |                     |             |            |                                                                                             |               |          |  |  |  |  |
| INT6       |     |     | K                                                                                                                                                                                                                   |                     |             |            |                                                                                             |               |          |  |  |  |  |
| IN17; P15  | 34  | 1/0 |                                                                                                                                                                                                                     |                     |             |            |                                                                                             |               |          |  |  |  |  |
| INTO PID   | 33  | 10  |                                                                                                                                                                                                                     |                     |             |            |                                                                                             |               |          |  |  |  |  |
| INT 10/P17 | 31  | 1/0 |                                                                                                                                                                                                                     |                     |             |            |                                                                                             |               |          |  |  |  |  |
| INT11/P11  | 30  | 1/0 | Group 2, programmable interrupt factive low) or                                                                                                                                                                     | 1/O pins (true log  | nc), Eac    | h pin is i | ndividu                                                                                     | illa broðrsmu | naole at |  |  |  |  |
| INT 12/P10 | 29  | 1/0 | an interrupt, an input port, or an output port.                                                                                                                                                                     |                     |             |            |                                                                                             |               |          |  |  |  |  |
| INT 13/P9  | 28  | 1/0 |                                                                                                                                                                                                                     |                     |             |            |                                                                                             |               |          |  |  |  |  |
| INT14/P8   | 27  | 1/0 |                                                                                                                                                                                                                     |                     |             |            |                                                                                             |               |          |  |  |  |  |
| INT 15/P7  | 23  | 1/0 | U                                                                                                                                                                                                                   |                     |             |            |                                                                                             |               |          |  |  |  |  |
| P0         | 38  | 1/0 |                                                                                                                                                                                                                     |                     |             |            |                                                                                             |               |          |  |  |  |  |
| P1         | 37  | 1/0 |                                                                                                                                                                                                                     |                     |             |            |                                                                                             |               |          |  |  |  |  |
| P2         | 26  | 1/0 |                                                                                                                                                                                                                     |                     |             |            |                                                                                             |               |          |  |  |  |  |
| P3         | 22  | 1/0 | Group 3, 1/O parts (true logic). Each pin is individu                                                                                                                                                               | ually programmab    | vie as an   | indut po   | ort or an                                                                                   | output port.  |          |  |  |  |  |
| P4         | 21  | 1/0 |                                                                                                                                                                                                                     |                     |             |            |                                                                                             |               |          |  |  |  |  |
| PS         | 20  | 1/0 |                                                                                                                                                                                                                     |                     |             |            |                                                                                             |               |          |  |  |  |  |
| P6         | 19  | 1/0 | μ                                                                                                                                                                                                                   |                     |             |            |                                                                                             |               |          |  |  |  |  |

| TABLE 4                                |
|----------------------------------------|
| TMS 9901 PIN ASSIGNMENTS AND FUNCTIONS |

Fig. 22

## 9901 INPUT/OUTPUT MAP

| ADDRESS CRU                                                                                                                                            | JBIT PORT D                                                                                                                      | DESIGNATION                                                                                                                                | PIN                                                                                                      | FUNCTION                                                                                                                                                                                                                                                             |
|--------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0000<br>0002<br>0004<br>0006                                                                                                                           | 0 CONTRO<br>1 INTERF<br>2 INTERF<br>3 INTERF                                                                                     | OL<br>RUPT 1<br>RUPT 2<br>RUPT 3                                                                                                           | 17<br>18<br>9                                                                                            | CONTROL<br>EXTERNAL<br>VDP VERTICAL SYNC.<br>KEYBOARD: :/.,MN=                                                                                                                                                                                                       |
| 0008                                                                                                                                                   | 4 INTERF                                                                                                                         | RUPT 4                                                                                                                                     | 8                                                                                                        | JOYSTICK: FIRE<br>KEYBOARD: ;LKJH SPACE                                                                                                                                                                                                                              |
| A000                                                                                                                                                   | 5 INTERR                                                                                                                         | RUPT 5                                                                                                                                     | 7                                                                                                        | KEYBOARD: POIUY ENTER                                                                                                                                                                                                                                                |
| 0000                                                                                                                                                   | 6 INTERR                                                                                                                         | RUPT 6                                                                                                                                     | 6                                                                                                        | KEYBOARD: 09876<br>JOYSTICK: DOWN                                                                                                                                                                                                                                    |
| 000E                                                                                                                                                   | 7 INTERR                                                                                                                         | RUPT 7 (P15)                                                                                                                               | ) 34                                                                                                     | KEYBOARD: 12345<br>JOYSTICK: UP                                                                                                                                                                                                                                      |
| 0010<br>0012<br>0014<br>0016<br>1<br>0018<br>1<br>001A - 1E                                                                                            | 8 INTERR<br>9 INTERR<br>0 INTERR<br>1 INTERR<br>2 INTERR<br>3 - 15 INTERR                                                        | UPT 8 (P14)<br>UPT 9 (P13)<br>UPT 10 (P12)<br>UPT 11 (P11)<br>UPT 12 (P12)<br>UPT 13 - 15                                                  | ) 33<br>32<br>31<br>30<br>29<br>28,27                                                                    | KEYBOARD: ASDFG SHIFT<br>KEYBOARD: QWERT<br>KEYBOARD: ZXCVB<br>NOT USED<br>RESERVED<br>NOT USED                                                                                                                                                                      |
| 0020 1   0022 1   0024 1   0026 1   0028 2   0020 2   0020 2   0020 2   0021 2   0022 2   0023 2   0030 2   0032 2   0036 2   0038 -   0038 -   0038 - | 6 PROGRA<br>7 PROGRA<br>8 PROGRA<br>9 PROGRA<br>0 PROGRA<br>1 PROGRA<br>3 PROG.<br>4 PROG.<br>5 PROG.<br>7 PROG.<br>8 - 32 PROG. | MMABLE 0<br>MMABLE 1<br>MMABLE 2<br>MMABLE 3<br>MMABLE 4<br>MMABLE 5<br>MMABLE 6<br>7 / INT. 1<br>8 / INT. 1<br>10 / INT. 1<br>11 / INT. 1 | & 23<br>38<br>37<br>26<br>22<br>21<br>20<br>19<br>5<br>23<br>4<br>27<br>2<br>28<br>1<br>30<br>5<br>31-34 | NOT USED<br>NOT USED<br>BIT 2 OF KEYBOARD SELECT (LSB)<br>BIT 1 OF KEYBOARD SELECT<br>BIT 0 OF KEYBOARD SELECT (MSB)<br>ALPHA LOCK KEY<br>CASSETTE MOTOR CONTROL 1<br>CASSETTE MOTOR CONTROL 2<br>AUDIO GATE<br>MAG TAPE DATA OUT<br>MAG TAPE DATA INPUT<br>NOT USED |

TABLE 8

## TABLE 10 PERIPHERAL ADDRESSES ----- ON CRU BUS

| CRU ADDRESSES | A3 | A4<br> | A5 | A6<br> | A7 | USE (FERIPHERAL)    | DEVICE<br>NUMBER |
|---------------|----|--------|----|--------|----|---------------------|------------------|
| >0000->0FFE   | 0  | X      | X  | X      | Х  | Internal use        |                  |
| >1000->10FE   | 1  | 0      | 0  | Ō      | Ō  | Reserved            | 0                |
| >1100->11FE   | 1  | 0      | 0  | 0      | 1  | Disk controller     | 1                |
| >1200->12FE   | 1  | Ō      | 0  | 1      | 0  | Reserved            | 2                |
| >1300->13FE   | 1  | Ō      | 0  | 1      | 1  | RS232,ports 1 and 2 | 3                |
| >1400->14FE   | 1  | 0      | 1  | 0      | 0  | Reserved            | 4                |
| >1500->15FE   | 1  | 0      | 1  | 0      | 1  | Rs232,ports 3 and 4 | 5                |
| >1600->16FE   | 1  | Ō      | 1  | 1      | 0  | Reserved            | 6                |
| >1700->17FE   | 1  | Ō      | 1  | 1      | 1  | Reserved            | 7                |
| >1800->18FE   | 1  | 1      | 0  | Ō      | Ö  | Thermal Frinter     | 8                |
| >1900->19FE   | 1  | 1      | 0  | Ō      | 1  | Future expansion    | 9                |
| >1A00->1AFE   | 1  | 1      | 0  | 1      | Ō  | Future expansion    | 10               |
| >1B00->1BFE   | 1  | 1      | 0  | 1      | 1  | Future expansion    | 11               |
| >1C00->1CFE   | 1  | 1      | 1  | 0      | 0  | Future expansion    | 12               |
| >1DOO->1DFE   | 1  | 1      | 1  | 0      | 1  | Future expansion    | 13               |
| >1E00->1EFE   | 1  | 1      | 1  | 1      | 0  | Future expansion    | 14               |
| >1F00->1FFE   | 1  | 1      | 1  | 1      | 1  | P-Code peripheral   | 15               |

59



Figure 23. TMS 9901 I/O Interface Section Block Diagram

Fig. 23

Figure 24. TMS 9901 Interupt Handling Logic.



Fig: 24

Figure 25. TMS 9901 Programmable System Interface.



.

62



Figure 26. TMS 9901 Interval Timer Section.
## VIDED DISPLAY PROCESSOR

## GENERAL DESCRIPTION

The TMS 9918 video display processor is capable of generating a complete NTSC color television video signal. The information to be displayed is stored in dynamic RAM, with the TMS 9918 generating all the necessary interfacing signals.

The VDP will generate a solid color border and background on which a 32 X 24 matrix of 8 X 8 picture element patterns is superimposed. In addition a high degree of mobility and resolution is provided in the form of the sprites, or dynamic patterns, which are further superimposed on the pattern display.

An option can be selected whereby the VDP can function as a 40X24 character alphanumeric terminal by setting the text command bit to one.

#### ARCHITECTURE

Figure. 29, p.71 shows the block diagram of the video display processor. Interface to the CPU is via an 8 bit bidirectional port controlled by two select and one address lines. Interface to the refresh RAM is via an 8 bit data bus, an 8 bit address/data bus, and 3 control lines. The VDP provides clock and synchronization signals to the system via the GROM CLK, CPU, CLK, and CPU INT and CPU INT signal lines.

Interface to the target television is provided by a composite video output signal.

## OSCILLATOR AND CLOCK GENERATION

The video display system is designed to operate with a 10.738635 MHz  $\pm$ / $\pm$  50 PFM crystal input to generate the required internal clock signals. A fundamental frequency parallel mode crystal is used as the frequency reference for the internal clock oscillator, which is the master time base for all system operation. This master clock is divided by 2 to generate the dot clock rate of 5.3 MHz. The master clock is divided by 3 to provide the CPU clock. The GROM clock is developed from the master clock divided by 24. additionally, the master clock and its compliment are divided by 3 in 2 stages to provide the 6 basic color phase free quencies which generate the color to the target color TV.

#### COLOR PHASE GENERATION

The 10.7+ MHz master clock and its compliment are used to generate a 6 phase 3.57545 MHz (+/-10Hz) clock to provide the video color signals and the color burst reference for use in developing the composite video output signal. Table 11 shows the six colors, the' standard phase shifts, and the color approximations provided by the VDP. While the VDP signals are not exact equivalencies, the differences can easily be adjusted by the color and tint control of the target color television. To insure compatibility with monochrome television receivers, an intensity level on the gray scale is assigned to each color signal.

## TABLE 11

Color vector relationships to the 3.079545 MHz color reference.

|         | STANDARD   | VDP FIRST     |           |
|---------|------------|---------------|-----------|
| COLOR   | PHASE      | APPROXIMATION | GOAL *    |
|         |            |               |           |
| Yellow  | 12 +/- 10  | 00            | 10 +/- 5  |
| Red     | 76 +/- 10  | 60            | 70 +/- 5  |
| Magenta | 120 +/- 10 | 120           | 120 +/- 5 |
| Blue    | 192 +/- 10 | 180           | 190 +/- 5 |
| Cyan    | 256 +/- 10 | 240           | 250 +/- 5 |
| Green   | 300 +/- 10 | 300           | 300 +/- 5 |

\* Electrical design will attempt to provide these color signals.

#### VIDED SYNC AND CONTROL GENERATION

The vertical and horizontal control signals are generated by decoding the horizontal counter increments and the vertical counter. Table 12 gives the relative count values of the screen display parameters. Within the active display area, the three least significant bits of the horizontal counter addresses the individual picture elements of each pattern displayed. Also, the active vertical counter addresses each individual line in the 8x8 patterns. The VDP operates at 264 lines perframe and approximately 60 frames per second in a non-interlaced mode of operation.

### TABLE 12

SCREEN DISPLAY PARAMETERS

| HORIZONTAL                | DOT CLOCK CYCLES |
|---------------------------|------------------|
|                           |                  |
| Horizontal active display | 256              |
| Right border              | 15               |
| Right blanking            | 8                |
| Horizontal sync           | 26               |
| Left blanking             | 2                |
| Color burst               | 14               |
| Left blanking             | 8                |
| Left border               | 13               |
|                           |                  |
|                           | TOTAL 342        |

| VERTICAL                |       | LINE |
|-------------------------|-------|------|
|                         |       |      |
| Vertical active display |       | 192  |
| Bottom border           |       | 26   |
| Bottom blanking         |       | 3    |
| Vertical sync           |       | 3    |
| Top blanking            |       | 13   |
| Top border              |       | 27   |
|                         |       |      |
|                         | TOTAL | 264  |

#### TELEVISION SCREEN DISPLAY

The VDP assembles three major elements into a composite for display on the target television: background, pattern matrix, and sprites. In normal operation the background is composed of the border of the active display area. The color of this region is specified by loading the specific code for the color desired into the screen background color register. All color of this region is specified by loading the specific code for the color desired into the screen background color register. All color information is described by four bit codes composed of three color select bits and an intensity bit giving a total range of 15 colors with one code reserved for the transparent state.

#### PATTERN GENERATION

The second element of the screen display is the 32X24 matrix of patterns formed and is the active display area. Each pattern is composed of an 8x8 matrix of picture elements. In a raster scanned television system each line of video information must be built and displayed. To accomplish this, a list of 768 8-bit names-- one for each pattern to be displayed-- is assembled in the screen refresh memory. The 8-bit name contains both color and display information.

#### EXTERNAL VIDEO OPERATION

In this mode any VDP - generated signal, other than the background, will be displayed as generated. When no signal is generated, the external signal is gated through. In both modes, however, the external sync, blanking, and color burst signals are controlling the VDP and the target TV system. No internal synchronization is made to the color burst. Therefore, if a color VDP generated signal is desired, an externally generated 10.7 MHz ( i.e., 3 x the color frequency ) must be provided to the XTL1 input and its non-over-lapping compliment to the XTL2 input.

## VDP RESET

The VDP is reset by applying a low signal to the RSET pin. This signal must last for at least 2 usec. Reset does the following: synchronizes all clocks to its negative going edge (this includes O1-O4 control clocks, CPUCLK, GROMCLK and color burst), sets horizontal and vertical counters to a known state, clears the internal command register, gets the text color and boarder color to black, and clears all status flags.

## POWER UP

VBB must be applied to the 4116s either before or at the same time as the other supplies and removed last. Failure to observe this precaution will cause dissipation in excess of the absolute maximum ratings due to internal forward bias conditions. This also applies to system use, where failure of the VBB supply must immediately shut down the other supplies. After power up, eight memory cycles must be performed to achieve proper device operation.

## HARDWARE DESCRIPTION

#### OSCILLATOR CIRCUITRY

An overview of the connections to the TMS 9918 VDP are given in figure 29,p71.

Timing signals for the TMS 9918 are derived from an on-chip oscillator which uses an external 10.7 MHz crystal. This crystal (Y100) in series with L100 is connected between pin 39 and 40. L100 is adjustable to set the frequency. C100 and C101 are the capacitors in the frequency determining network. R103 is added in parallel to Y100 and L100 to lower the impedance of the network, thus assuring a proper voltage swing at pin 39. Also a 5 volt voltage is fed to pin 39, (R102 and L107 for decoupling). This voltage is used for proper start-up of the oscillator.

#### FOWER CONNECTIONS

The TMS 9918 uses only one power supply voltage. Fin 12 (VSS) is connected to the system ground, and FIN 33 (VCC) to the +5 volt power supply. C102, C103, C104 and L101 are used to suppress noise on the 5 volt line.

#### GROM CLOCK

The 10.7 MHz oscillator frequency is internally divided by 24. This gives a frequency of 4  $\pm$  5.8 kHz. This frequency is buffered and fed to pin 37 and used as the GROM clock.

## CPU CLOCK

The 3.58 MHz CPU clock on PIN 38 is used by TMS 9919 sound processor (on units which use the SN 76489).

#### RESET

The TMS 9918 is reset during power up or with a solid state software command module by using the reset signal of U601 pin 4. This signal is monitored by the 9918 on pin 34.

#### CHIP SELECTION LOGIC

The VDP is selected with CSW on pin 14 or CSR on pin 15 are low.

When CSW is low the microprocessor can write to the VDF, when CSR is low, data can be read from the VDF. The MODE signal on pin 13 is used in combination with CSW and CSR to select four basic modes of operation.

The selection logic which enables CSW or CSR is given in figure 27, p69.

Selection pins Y2 ( pin 13 ) and Y13 (pin 12) of USO5 (74LS138) are used to distinguish between a write or read operation. The write selection from pin 12 is combined with the WE signal in OR-gate USO7. Thus only a VDP write can occur when WE is low.

## DATA BUS INTERFACING

Pins 17 through 24 (data lines CDO through CD7) are directly connected to DO through D7 of the TMS 9900. Thus circumventing the 16 to 8 bit interfacing circuit.

## DYNAMIC RAM INTERFACING

Dynamic RAM memory is given in figure 53, p.133. The TMS 9918 uses pins 1 through 11 and 25 through 32 for interfacing the dynamic RAM. Fins 3 through 10 are the address/data lines for the TMS 4116 (line 10 only for data). RAS on pin 1 and CAS or pin 2 are the row and address strobe lines for loading the address in the 4116's (and refresh operation), and are connected to the corresponding pins 4 and 14 of the RAM's. R/W on pin 11 of the TMS 9918 distinguishes between a read or write to the RAM. This signal is delayed by the four inverting buffers U101 for timing purposes in units manufactured not using the TMS 9918A. During a read all 8 separate output bits of the RAM's form an eight bit data bus which is connected to RDO through RD7 (pin 25 through 32) of the TMS 9918.

#### VIDEO OUTPUT

The composite NTSC video signal is available on PIN 36 of the TMS 9900. This signal is fed to the video amplifier in figure 53, p. 133. This amplifier has two purposes:

- 1. To amplify the video signal.
- 2. To provide the desired output impedance of 75 ohms.

#### 99/4

The first stage of the amplifier consisting of 0200 is a common base amplifier which has enough bandwidth to amplify the video signal. R201 is used to adjust the gain of the vidio amplifier. The second stage with 0201 has no voltage amplification since this stage is used as an impedance tranformer to provide the 75 ohm output inpedance. R208 and C205 is a filter which decouples the video noise from the +12 volt power line. L200 and C207 have the same purpose and the voltage from this filter can be used to supply power for an RF modulator.

#### 99/4A

In the 99/4A, the first stage of the video amplifier (0200) is a PNP transistor connected in the common collector configuration. Input to 0200 is through a filter which is designed to roll off signal frequencies above the 6 MHz video bandwidth. Diodes CR200 & CR201 clamp the DC level after C201. 0201 is an emitter-follower and is used as an impedence transformer to achieve the required 75 ohm video output.





Fig. 27

69



-

-



## Fig. 28

.



| REGISTER              | MSB     |            |               |               |               |                           |                             | LSB            |
|-----------------------|---------|------------|---------------|---------------|---------------|---------------------------|-----------------------------|----------------|
| o                     | o       | O          | 0             | o             | 0             | ο                         | мз                          | EV             |
| •                     |         |            |               |               |               |                           |                             | ,,             |
| 1                     | 4/16K   | BLANK      | IE            | M1            | М2            | o                         | SIZE                        | MAG            |
|                       |         |            |               |               |               |                           |                             |                |
| 2                     | 0       | O          | 0             | 0             | NAME          | I<br>TABLE I              | BASE ADI                    | DRESS          |
|                       |         |            |               |               |               |                           |                             |                |
| 3                     |         | 1          | COLC          | I<br>DR TABLE | I<br>BASE AC  | DRESS                     | 1                           | 1              |
|                       |         |            |               |               |               |                           | _                           |                |
| 4                     | 0       | o          | 0             | o             | o             | PATTE<br>BASE             | I<br>RN GENE<br>ADDRESS     | RATOR          |
|                       |         |            | <b>,</b>      |               |               | . <u></u>                 |                             |                |
| 5                     | 0       |            | 1<br>SPF<br>1 | I             | 1<br>RIBUTE T | 1<br>ABLE BA              | I<br>SE ADDR                | ESS            |
|                       | <u></u> | <b></b>    | ••••••        | <b>.</b>      |               | · · <del>2</del>          |                             |                |
| 6                     | 0       | 0          | 0             | 0             | 0             | SPRITI<br>GENEI<br>ADDR   | E PATTER<br>RATOR B.<br>ESS | ih<br>ASE<br>L |
|                       |         | 7          |               |               |               |                           |                             |                |
| 7                     |         | техт<br>1  | 1<br>COLOR1   | ۱<br>۱        | TEXTC         | 4<br>OLOR <sub>0</sub> /8 | 1<br>ACKDRO                 |                |
|                       | ·       | - <b>-</b> |               | - <b>-</b>    |               |                           |                             |                |
| STATUS<br>(READ-ONLY) | F       | 55         | с             |               | •<br>FIFTH    | I SPRITE                  |                             | ·              |

VOP REGISTERS

.

## SOUND GENERATION CONTROLLER

#### GENERAL DESCRIPTION

#### 

The TMS 9919 Sound Generation Controller (SGC) is an I L component designed to provide low cost tone/noise generation capability in microprocessor systems. The SGC is a data bus based I/O peripheral.

KEY FEATURES

- # 3 programmable tone generators
- \* Programmable white noise generator
- # Programmable attenuation
- 8 Ohm speaker drive capability
- # External audio input
- \* 16 FIN package
- # 1 L technology

#### DEVICE ARCHITECTURE

The device consists of three programmable tone generators, a programmable noise generator, a clock scaler, and an audio summer output buffer. The SGC has a parallel 8 bit interface through which the microprocessor transfers the data which controls the audio output.

#### TONE GENERATORS

Each tone generator consists of a frequency synthesis section and an attenuation section. The frequency synthesis section requires 10 bits of information (FO-F9) to define half the period of the desired frequency (n). This information is loaded into a 10 stage tone counter, which is decremented at a N/16 rate where N is the input clock frequency. When the tone counter decrements to zero, a borrow signal is produced. This borrow signal toggles the frequency flip-flop and also reloads the tone counter. Thus, the period of the desired frequency is twice the value of the period register. The frequency can be calculated by the following:

The output of the frequency flip-flop will feed into a four state attenuator. The attenuator values, along with their bit position in the data word, are shown in table. 14 multiple attenuation control bits may be true simultaneously. Thus, the maximum attenuation is 30 db.

TABLE 14: ATTENUATION CONTROL

| ΒI | T FO | SITI | ON |      |     |
|----|------|------|----|------|-----|
| AO | A1   | A2   | A3 | WE I | GHT |
|    |      |      |    |      |     |
| Ō  | 0    | Ō    | 1  | 2    | DB  |
| O  | 0    | 1    | 0  | 4    | DB  |
| Ō  | 1    | 0    | 0  | 8    | DB  |
| 1  | 0    | 0    | 0  | 16   | DB  |
| 1  | 1    | 1    | 1  | OF   | FF  |

#### NOISE GENERATOR

The noise generator consists of a noise source and an attenuator.

The noise source is a 15 stage shift register with an exclusive OR feedback network. The feedback network will have provisions to protect the shift register from getting locked in the zero state.

The feedback network will have two feedback tap configurations as determined by the FB control bit.

TABLE 15: NOISE FEEDBACK CONTROL

| FB | CONFIGURATION    |
|----|------------------|
|    |                  |
| Ō  | "Feriocic" noise |

1 "White" noise

i onice noise

Whenever the FB bit is changed, the shift register is cleared. The shift register will shift at one of four rates as determined by the two NF bits. The fixed shift rates are derived from the input clock.

TABLE 16: NOISE GENERATOR FREQUENCY CONTROL

| BITS |     |     |            |           |
|------|-----|-----|------------|-----------|
|      | NFO | NF1 | SHIFT RATE |           |
|      |     |     |            |           |
|      | 0   | 0   | N/512      |           |
|      | 0   | 1   | N/1024     |           |
|      | 1   | 0   | N/2048     |           |
|      | 1   | 1   | Tone Gen.  | #3 output |
|      | 1   | 1   | iule dell. | πο σατρ   |

The output of the noise source is fed to an attenuator similar to the tone generator attenuator.

#### AUDIO SUMMER/OUTPUT BUFFER

The summer is a conventional 1<sup>2</sup>L operational amplifier summing circuit. It will sum the three tone generator outputs, noise generator output, and an external audio source. The output buffer will generate up to 100 milliamperes into a 8 ohm load, if all sources are operating at maximum levels. It is assumed that the speaker will be AC coupled to the chip.

#### CPU/SGC INTERFACE

The microprocessor interfaces with the SGC by means of the 8 data lines and 3 control lines (WE, CE and READY). Each tone generator requires 10 bits of information to select the frequency and 4 bits of information to select the attenuation. A frequency update requires a double byte transfer, while an attenuator update requires a single byte transfer.

## CONTROL REGISTERS

The SGC has eight internal registers which are used to control the three tone generators and the noise source. During all data transfers to the SGC, the first byte contains a three bit field which determines the destination control register. The register address codes are shown in Table 17.

TABLE 17: REGISTER ADDRESS FIELD

| RO          | R1         | R2          | DESTINATION CONTROL REGISTER                               |
|-------------|------------|-------------|------------------------------------------------------------|
| 0<br>0<br>0 | <br>0<br>1 | 0<br>1<br>0 | Tone 1 frequency<br>Tone 1 attenuation<br>Tone 2 frequency |
| Ō           | 1          | 1           | Tone 2 attenuation                                         |
| 1           | Ō          | Ō           | Tone 3 frequency                                           |
| 1           | Ō          | 1           | Tone 3 attenuation                                         |
| 1           | 1          | Ō           | Noise control                                              |
| 1           | 1          | 1           | Noise attenuation                                          |

. .

## DATA FORMATS

The formats required to transfer data are shown below.

UPDATE FREQUENCY (2 BYTE TRANSFER)

|        | :   | REG ADDR<br>RO!R1!R2! | 1<br>1<br>1<br>1 | DA<br>F6!F7! | TA<br>F8!F | <br>7! | :<br>:<br>: 0 |   | x     | i<br>I<br>IFO | <br> <br> <br> <br> <br> | F1  | <br>F2 |       | F3   |       | <br>F4 |    | <br>F5 |          |
|--------|-----|-----------------------|------------------|--------------|------------|--------|---------------|---|-------|---------------|--------------------------|-----|--------|-------|------|-------|--------|----|--------|----------|
| <br>B1 | . T | O FIRST               |                  | BYTE         | BIT        | 7      | BI            | т | <br>0 | SE            | EC                       | DND | <br>   | <br>I | ЭІТЕ | <br>E |        | БJ | ст 7   | - —<br>7 |

## UPDATED NOISE SOURCE (SINGLE BYTE TRANSFER)

|   | 1  |        | REG ADDR<br>R0!R1!R2 | <br> <br>  FB<br> | <br> <br>  X<br> | <br>SHIFT<br>NFO NF1 | : |
|---|----|--------|----------------------|-------------------|------------------|----------------------|---|
| E | IT | о<br>О |                      |                   |                  | <br>BIT 7            |   |

## UPDATE ATTENUATOR (SINGLE BYTE TRANSFER)

| <br>! 1<br>!<br>! | <br> | REG ADDR<br>RO!R1!R2 | <br>DATA<br>A0!A1!A2!A3 |  |
|-------------------|-----------------------------------------------------------------------|----------------------|-------------------------|--|
| BIT               | 0                                                                     |                      | <br>BIT 7               |  |

# HARDWARE DESCRIPTION

## POWER CONNECTIONS

The TMS 9919 uses a sigle 5 volt power supply on pin 16, L500 and L501 is used to decouple the power line.

#### CLOCK

The TMS 9919 uses a 3.58 MHz clock signal on pin 14, derived from the TMS 9918 video display processor. The SN94624 uses the 447.5 KHz GROM clock.

#### DATA BUS

The TMS 9919 uses an eight bit parallel data bus connected directly to the 99/4 data bus.

#### SOUND PROCESSOR SELECTION LOGIC

The logic which selects the sound processor is given in figure 30, p.77.

### READY

The READY line of the TMS 9919 is directly connected to the system READY line. This wired-OR convention is possible because NAND gate U506 is an open collector.

#### WΕ

The WE signal distinguishes between a write to or a read from the TMS 9919.

#### EXTERNAL SOUND

External sound is fed to pin 9 of the TMS 9919. The 99/4 system uses two sound signals on pin 9.

External sound from the cassette interface connector.
Sound from the speech unit.

R501 is used to reduce the speech signal to an appropriate level.

#### SOUND OUTPUT

Sound is available on pin 7. C502 and R511 are used to reduce the bandwidth. C503, C504 and L501 are used for the same purpose.





Fig. 30

## GENERAL DESCRIPTION

Keyboard and remote control are scanned under software control. The keyboard is scanned by 5 select lines. The 9 detect lines are monitored by the TMS 9901 programmable system interface (see figure 47, p. 127).

Two other select lines are used for selecting the remote handheld control unit, the five detect lines of these units are shared with those of the keyboard.

## HARDWARE DESCRIPTION

The keyboard and remote handheld unit interfaces to the microprocessor via the TMS 9901 programmable system interface. Fins F2 F3 and P4 of the 9901 are programmed as outputs and used as input for U302 (74LS156), a dual 2 to 4 decoder. This IC is wired as a three to eight line decoder. Outputs are used to scan the keyboard and joystick port.

Two outputs of U302 (pin 4 and 5) are used to select the remote handheld control units. Full up resistors R322 and R329 are used to supply enough current when the outputs are in the logic high state (+5 volt). CR 301 in combination with R321 and CR302 with R320 are used to get a good defined logic zero state, since R320 and R321 which are connected to the +5 volt supply generates a -.6 volt drop over CR301 and CR302.

## KEYBOARD SCANNING

The keyboard is divided in two parts. Each part consisting of 4 rows with 5 keys. The outputs of the right four rows (INT 3, 4, 5 and 6) and the left four rows (INT 7, 8, 9 and 10) are connected to the preprogrammed inputs of the TMS 9901 with the same names. These inputs are scanned under software control to determine which key is pressed down. The keyboard uses pull-up resistors for putting all lines in the logic one state when no key is hit. The capacitors are used for reducing RF interference.

### REMOTE HANDHELD CONTROL UNIT

The handheld unit uses the same inputs to the TMS 9901 as the righthand keyboard side.

#### 99/4A KEYBOARD DESIGN

The 99/4A keyboard circuit is significantly changed from the design used in the 99/4, although the principle of operation is the same. Seven outputs are used on U302, and one additional interupt line (PS), in order to scan the additional keys used on the 99/4A keyboard.

## CASSETTE INTERFACING CIRCUITRY

#### GENERAL DESCRIPTION

## 

The cassette interfacing circuit enables the 99/4A to store and read data from a normal cassette recorder. The interfacing circuitry consists of 3 distinct parts: the control circuitry, the write circuitry and read circuitry.

#### CASSETTE CONTROL CIRCUITRY

This part consists of two solid state switches which are used for remote controlling of up to two cassette recorders.

#### WRITE CIRCUITRY

The write circuitry supplies digital data which has been waveshaped cassette recorder. It uses a TMS 9901 output gate and a second order filter to supply a signal of the desired shape and amplitude. If two cassette recorders are used, then both will use use the same write signal, but only one recorder is selected at a time by the control circuitry.

#### DATA FORMAT

The 99/4 uses a biphase coding technique to generate the serial data stream. A standard time interval (bit cell) is used in the encoding software, in the following way:

- A. A binary one is represented by 2 bit cells both bit cells of opposite polarity.
- B. A binary zero if represented by 2 bit cells, both bit cells of the same polarity.
- C. After a binary bit is written, the next bit will start with an opposite polarity referenced to the last bit cell.

#### AUDIO GATE

A special feature is incorporated which consists of a solid state switching circuit. This circuit can switch the audio signal of the cassette recorder to the sound processor.

#### CONTROL CIRCUITRY

Since the two control circuits are identical, only a description of one cassette control circuit is given (see figure 54, p. 134). Fin 19 (F6) of the TMS 9901 programmable system interface is used to enable or disable 0402. When enabled, the LED in opto-couplor U401 turns on. R415 is used to reduce the current through the LED. Outputs 4 and 5 of the opto-coupler are used to put transistor 0401 in the conductive state, thus enabling the motor drive of the cassette recorder.

#### WRITE CIRCUITRY

The write signal is generated on pin 28 of 407 the TMS 9901. The differentiating filter consisting of R402, C408, C407, R400, R401 and C400 shapes the signal.

#### READ CIRCUITRY

First part of the read circuitry consists of an operational amplifier which performs amplification and pulse shaping of the read signal. R408 and R410 determine the gain of the amplifier. C402, C409 and C411 are for pulse shaping purposes. R406 is the resistive load for the cassette recorder.

### GROUNDING

Since the definition for ground and signal on the output jack of the cassette recorder depends on the type used, R409 is applied to allow operation with both types of recorders.

## HYSTERESIS CIRCUIT

The hysteresis circuit consists of a second amplifier with positive feedback, the feedback network consisting of R412 and R411. C410 is used to make the circuit less succeptible to undesired signals. CR402 is used to limit the negative output swing, thus avoiding damage to the TMS 9901. R413 is used to limit the current through diode CR402.

#### I/O BUS

## GENERAL DESCRIPTION

The 99/4A I/O bus provides maximum flexibility for operation with external devices. It provides peripherals with memory and CRU I/O buses. The memory bus (with 8 bit data bus) is used for instruction fetch from control ROM in the peripherals and for data transfer to/from memory mapped peripherals. The CRU bus is used for peripherals enable/disable and for device control and data transfer to/from CRU mapped peripherals.

The TMS 9900 accesses each peripheral to obtain instructions from the device service routine (DSR) read only memory. Since each peripheral contains its own DSR, the 99/4A does not have to be designed to anticipate future peripheral requirements. The dual I/O bus capability, along with interrupt handling and external DSR's provide flexibility at low cost.

#### MEMORY ALLOCATION

The third memory block (addresses 4000-SFFF) of the 99/4A is predecoded and made available at the I/O port for the peripheral. Addresses A000 - FFFF are available for memory expansion. For the speech module (addresses 90XX - 94XX), a predecoded line is available at the I/O bus.

#### CRU ALLOCATION

Of the available 4K of CRU bits, the first 1K (addresses 0000 - 07FE) are used internally in the Home Computer. The second 1K (addresses 0800 + 0FFE) are reserved for future use. The last 2K addresses 1000 - 1FFE) are reserved for the peripherals to be plugged in the I/O port. A block of 128 CRU bits is assigned to each peripheral as listed below.

## TABLE 18 CRU ALLOCATION

| CRU ADDRESS | PERIPHERAL               |
|-------------|--------------------------|
|             |                          |
| 1000        | Reserved                 |
| 1100        | Disk System              |
| 1200        | Modem                    |
| 1300        | Primary RS232            |
| 1400        | Not Assigned             |
| 1500        | Secondary RS232          |
| 1600        | Not Assigned             |
| 1700        | HEX BUS (TM)             |
| 1800        | Thermal Frinter          |
| 1900        | Not Assigned             |
| 1A00        | Not Assigned             |
| 1800        | Not Assigned             |
| 1000        | Video Controller Card    |
| 1D00        | IEEE 488 Controller Card |
| 1E00        | Not Assigned             |
| 1F00        | F-Code                   |

## INTERRUPT HANDLING

The interrupt available on the I/O port is one of the maskable interrupts of the TMS 9901 programmable systems interface.

#### BUFFERING

All I/O signals must be able to drive two LS-type loads (with the exception of the data bus). In addition, peripherals generating CRUIN, READY/HOLD, LOAD and EXT INT shall buffer these signals before putting them on the I/O bus.

#### I/O READ

A CPU read cycle for the external device consists of two 8-bit read cycles (figure 18, p46). The two bytes read are assembled as a 16 bit word before they are presented to the 9700.

MEMEN goes low true at the beginning of clock cycle 1. At the same time DBIN goes high true. WE stays high false during the entire cycle. At the same time that MEMEN goes true, the address bus goes active. In order for the noise and the glitches (associated with crosstalk and simultaneous switching) to go away, we allow a minimum of 100 ns for the address lines to settle. MBE (see memory selection logic) goes true during the leading edge of Q2 of clock cycle 1. Data read from the peripherals will be valid 750 ns after the start of clock cycle 1. The CFU will look at the full 16 bit data bus during the leading edge of Q1, of clock cycle 2. Under worst-case conditions, data must be valid 100 ns before that time.

### I/O WRITE

Figure 17,p45 shows a 16 bit I/O write cycle. As described earlier it is composed of two 8-bit writes. A write cycle will always be preceded by an ALU cycle. MEMEN and DBIN go true at the start of the cycle. A settling time of 100 ns (minimum) is allowed for the address lines to settle down. WE goes true (low) on the leading edge of 02, during the wait states, and stays true for 660 ns (typically). During a read and a write, the odd byte is accessed first, followed by an even byte. A15/CRU out changes its state 970 ns (typically after the cycle is initiated. The second 8-bit write cycle is identical to the first 8-bit write. MBE stays true (low) during the entire (1.8 usec) cycle.

#### SPEECH INTERFACE

The I/O port has 4 lines dedicated for use by the speech module:  $\pm 5, \pm 5$ , speech block enable (SBE) and audio in. SBE is decoded by the 99/4A for addresses 9000 and 9400 (write and read). For the write cycle, SBE goes active after the address and data lines are valid.

## GROM INTERFACE ON I/O PORT

All signals are provided to use GROM's in external devices. Decode for GROM select must be performed in the external device.

### CRU TIMING

CRU interface timing is shown in figure 10, p30. The CRUOUT cycle is composed of 2 clock cycles. The CRU bit address when placed on the address bus AO through A14 is allowed to settle for 100 ns (minimum). CRUCLK is a 80 ms low true signal which occurs on the trailing edge of Q1, of clock cycle 2. CRUOUT data is valid at the start of clock cycle, and is latched by the CRUCLK in the repective peripheral. CRUIN also consists of 2 clock cycles of 660 ns (typically). Again we allow 100 ns for the address bus to settle down. The CPU samples the CRUIN line on the leading edge of Q1 of cycle 2. Data must be valid 40 ns (min) before that.

#### HARDWARE DESCRIPTION

-----

An overview of the hardware used to buffer the IN and OUTPUT signals on the I/O bus is given in figures 55, p135 and 51, p131.

#### ADDRRESS BUS BUFFERING

US03, US09 and US10 are used to buffer address lines A0 through A14. US10 is only used for A0, A1, A2 and A15/CRUOUT. This last signal has a series resistor RS12 to reduce transients on the line.

WE is buffered by US10 on the output (pin 10). A series resistor R505 is used to reduce transients.

#### CRUCLK

The CRUCLK signal from the 99/4A in inverted in U602 and then buffered by U510. Again a series resistor R507 is used to reduce transients. The buffered signal is also used on the GROM port.

#### 03

03 is buffered by US10, R506 used to reduce transients.

#### MBE

MBE is buffered by U510.

#### DBIN

DBIN is buffered by the two inverters U508.

#### DATA BUS

Since the data bus in buffered by U616 in the interfacing circuit, no additional buffering is necessary. However to meet loading requirements a special pull-up/pull down circuit is added. When DBIN is low, 0500 is in the on state.

R519 is used to reduce the base current in Q500. When in the on state, resistor pack R500 is connected to ground, thus generating a pull-down. When DBIN is low, Q500 is disabled. CR501, R520, R521, CR502 and R522 compose a circuit which gives a voltage of 5 volts to the resistor pack. Thus a pull-up exists when DBIN is low.

OUTPUT BUS FIN CONNECTIONS An overview of the I/O bus pin connections is given on p104.

### POWER SUPPLY BOARD

## GENERAL DESCRIPTION

The US power supply consists of an external wall transformer and a regulator board inside the Home Computer. Connection between the console and wall transformer is made by a 4 pin connector. The regulator board supplies the 99/4A three regulated voltages: +12, +5 and -5 volt. The +12 and -5 volt supplies uses a normal three pin fixed regulator and the +5 volt supply uses a switching regulator circuit.

#### SWITCHING REGULATOR

The switching regulator used is a ua 723 C. A schematic diagram is given in figure 49, p129. In essence the ua 723 is a normal series regulator, but it is connected in such a way that it behaves like a switching regulator. From the block diagram it can be seen that the regulator consists of a compensated voltage reference, and error amplifier and a current limiting circuit.

#### HARDWARE DESCRIPTION +12 VOLT SUPPLY

The +12 volt regulator circuit shares the rectifier circuit with the +5 volt regulator. This circuit uses an input filter consisting of L1, L2, C1, C2, C3 and C4. The filter is used to reduce RF interference on the mains. D1, D2, D3 and D4 compose the bridge rectifier. C9 and C17 are used to reduce the ripple. The DC revoltage is fed to the three pin fixed regulator U1, which regulates the input voltage down to \_+12 volt. C10 is used to reduce voltage swing due to fast changing load conditions.

#### -5 VOLT SUPPLY

The -5 volt supply uses a separate winding on the tranformer. L3 together with C5 and C6 compose an RF filter. The AC voltage is rectified by D5, C8 reduces the ripple on the output of the rectifier. U2 is a 5 volt fixed regulator. C7 on the output reduces voltage swing due to fast changing load conditions.

## +5 VOLT SUPPLY

## REFERENCE VOLTAGE

The reference voltage for the regulator is derived from the +12 volt. R1, D7 and zener diode D8 compose a 7 volt reference. D7 is used to compensate for temperature variations. C12 is used to reduce noise. The 7 volt reference is divided by R11, R15 and R16 through R19, R16 through R19 are supplied with jumper wires which can be cut in such a way that the voltage on the non-inverting input of comparator U4 is 5 volts. Since this comparator has an open collector output, R12 is used as a pull-up. R14 connected between the output and the inverting input (pin 2) sets the voltage gain to 1. R13 provides a small positive feedback. Since in this configuration the comparator behaves as a unity gain amplifier, the voltage on the inverting input (pin 2) is equal to that of the divider. This voltage-is used as a reference for the switching reculator U3. C16 is used to ensure a slow starting up of the +S volt regulator; thus the starting condition that the -5 volt is applied first to the circuitry inside the 99/4A is met. C16 also determines the frequency at which the -5 volt regulator switches.

SWITCHING REGULATOR

Switching regulator U3 (UA 723 C) uses the following circuitry:

#### REFERENCE VOLTAGE

The reference voltage on pin 2 of U4 is connected to the non-inverting input of U3 (pin 5).

#### FEEDBACK VOLTAGE

The +5 volt is directly connected to the inverting input of U3 (PIN 4).

## POWER CONNECTION

Power is connected to pin 12 of U3 via R3. C13 is used to reduce voltage swings on the power line. Since the power comes from the +12 volt supply, the switching regulator only works when this voltage is present. Ground connection is to pin 7.

#### FREQUENCY COMPENSATION

Frequency compensation is performed by C11 on pin 13.

### REGULATING CIRCUIT

The output of U3 on pin 11 is used to switch the current through L4 after amplification by 01 and 02. R5 reduces the input current current of 01. R4 and R6 are used to ensure that both 01 and 02 are in the non-conducting state when not enabled by U3. The flyback circuitry consists of L4 and D9. The output voltage ripple is reduced by C14 and C15.

#### CURRENT LIMITING

Current limiting is done by using the voltage drop over R9-R10 and comparing this with the voltage on the cathode of the diode, the divider circuit consisting of R7, R8 and D10. D10 is used for temperature compensation.

## TEXAS INSTRUMENTS HOME COMPUTER TROUBLESHOOTING GUIDE

This guide will take you by the problem, not neccessarily to the problem. You still need your basic troubleshooting skills. This guide is aimed at the new technician but still can be referenced when in doubt.



(Compiled by Curt Larsen and Greenwood).





















Won't Respond To Any Key Test:







.










.



TOP

BOTTOM

| 2  | SBE              | 1  | +5 V         |
|----|------------------|----|--------------|
| 4  | -EXT INT         | 3  | RESET        |
| 6  | A10              | 5  | A5           |
| 8  | A11              | 7  | A4           |
| 10 | A3               | 9  | DBIN *       |
| 12 | READY            | 11 | A12          |
| 14 | A8               | 13 | -LOAD        |
| 16 | A14              | 15 | A13          |
| 18 | A9               | 17 | A7           |
| 20 | A2               | 19 | A15          |
| 22 | -CRU CLOCK       | 21 | GROUND       |
| 24 | -03 SYSTEM CLOCK | 23 |              |
| 26 | -WE              | 25 |              |
| 28 | -MBE             | 27 | GROUND       |
| 30 | Al               | 29 | A6           |
| 32 | -MEMEN           | 31 | AO           |
| 34 | D7               | 33 | CRU IN       |
| 36 | D6               | 35 | D4           |
| 38 | D5               | 37 | DO           |
| 40 | D1               | 39 | D2           |
| 42 | D3               | 41 | HOLD / IAQ * |
| 44 | SOUND IN         | 43 | -5 V         |

SBE - SPEECH BLOCK ENABLE MBE - MEMORY BLOCK ENABLE EXT INT - EXTERNAL INTERUPT MEMEN - MEMORY ENABLE DBIN - DATA BUS IN IAQ - INSTRUCTION AQUISITION GROM PORT CONNECTOR

| GROUND<br>GROM VSS<br>GROM READY<br>-5 V<br>GROM CLOCK<br>DBIN<br>A14<br>GROM SELECT<br>+5 V<br>D0<br>D1<br>D2<br>D3<br>D4<br>D5 | 35<br>33<br>31<br>29<br>27<br>25<br>23<br>21<br>19<br>17<br>15<br>13<br>11<br>9<br>7 | 36<br>34<br>32<br>30<br>28<br>26<br>24<br>22<br>20<br>18<br>16<br>14<br>12<br>10<br>8 | GROUND<br>-ROM G<br>-WE<br>A4<br>A5<br>A6<br>A3<br>A7<br>A8<br>A9<br>A10<br>A11<br>A12<br>A13<br>A15/CRU OUT | FRONT- <del>)</del> |
|----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|---------------------|
| D3<br>D4                                                                                                                         | 9                                                                                    | 10                                                                                    | A12<br>A13                                                                                                   |                     |
| D5                                                                                                                               | 7                                                                                    | 8                                                                                     | A15/CRU OUT                                                                                                  |                     |
| D6                                                                                                                               | 5                                                                                    | 6                                                                                     | CRU IN                                                                                                       |                     |
| RESET                                                                                                                            | 1                                                                                    | 2                                                                                     | GROUND                                                                                                       |                     |
|                                                                                                                                  |                                                                                      |                                                                                       |                                                                                                              |                     |

### CASSETTE I/O PORT

1 - CASSETTE 1 MOTOR CONTROL 2 - CASSETTE 1 MOTOR CONTROL 3 - MAG OUT RETURN (GROUND) 4 - CASSETTE AUDIO INPUT 5 - MAG OUT 6 - CASSETTE 2 MOTOR CONTROL 7 - CASSETTE 2 MOTOR CONTROL 8 - MAG IN 9 - MAG IN RETURN (GROUND)

<u>5</u>/ 9/ 234 8

JOYSTICK I/O

- 1 -2 - JOYSTICK B 3 - UP 4 - PUSH BUTTON 5 - LEFT
- 6 -
- 7 JOYSTICK A
- 8 DOWN
- 9 RIGHT

2 3 4 5, 8 a 7

VIDEO I/O

1 - +12 VOLTS 2 - GROUND 3 - AUDIO OUT 4 - COMPOSITE VIDEO OUT 5 - GROUND

3 **5** 4 1

### RAM TRAP OPERATING INSTRUCTIONS



BEFORE EACH TEST MAKE SURE THE UNIT UNDER TEST IS SWITCHED OFF.

START UP PROCEDURE:

- 1. Turn Unit To Be Tested "Off"
- 2. Insert RAM Trap
- 3. Select Test Mode On Ram Trap
- 4. Turn "On" Unit To Be Tested
- 5. Press LOAD Switch

# MAINFRAME RAM - TRAP

### COMPONENT LAYOUT:



PARTS LIST:

| C - 1, C - 2 | 0.1uf capacitors | R-1       | 560 A                            |
|--------------|------------------|-----------|----------------------------------|
| 1C- 1        | 74LS138N         | R-2       | 100k1 All resistors are ¼ watt   |
| 1C- 2        | 74LS21N          | R-3 - R-8 | 100 ~ 5%                         |
| 1C- 3        | 74LS74AN         | R-9, R-10 | 2.2k 🔨                           |
| 1C- 4        | 74LS174N         | S-1       | SPST Push button switch(momentar |
| 1C- 5        | TMS4036-2NL      | S-2, S-3  | SPST Toggle switches N.O)        |
| 1C- 6        | 2532 (EPROM)     | -         |                                  |

By 3.4.80



109

Br: [Hulu 3.28.80

# LS138\_

- 3 TO 8 LINE DECODER/MULTIPLIER
- 2 STATE OUPUT: 1) HIGH 2) LOW
- 3 ENABLES, G2A & G2B ACTIVE LOW, G1 ACTIVE HIGH
- ENABLES CAN BE USED AS INVERTING OR NON-INVERTING INPUT TO MULTIPLEX DATA









|     |     | VPUT: | 5    |      |    |    |    |     |     | -  |    |    |
|-----|-----|-------|------|------|----|----|----|-----|-----|----|----|----|
| ENA | BLE | SI    | ELEC | Ť    |    |    | ç  | 001 | PUT | 5  |    |    |
| G1  | G2* | C     | 8    | A    | YO | Y1 | ٧2 | Y3  | 74  | ¥5 | YS | Y  |
| x   | H   | ×     | x    | X    | н  | н  | н  | н   | н   | н  | н  | н  |
| L   | ×   | ×     | x    | ×    | н  | н  | н  | н   | н   | н  | н  | н  |
| н   | L   | L     | Ŀ    | ίL.  | L  | н  | н  | н   | н   | н  | н  | н  |
| н   | L   | L .   | L.   | н    | н  | L  | н  | н   | н   | н  | н  | н  |
| н   | L   | L     | н    | L    | н  | н  | L  | н   | н   | н  | н  | н  |
| н   | L   | L     | н    | н    | н  | н  | н  | L   | н   | н  | н  | н  |
| н   | L   | н     | L    | . Ц. | н  | н  | н  | н   | L   | н  | н  | н  |
| н   | L   | н     | L    | н    | н  | н  | н  | н   | н   | L  | Ħ  | ы  |
| н   | L   | н     | н    | L    | н  | н  | н  | н   | н   | н  | ι  | н  |
| н   | L   | н     | н    | н    | н  | н  | н  | н   | н   | н  | н  | t. |

H = nigh level; L = low level; X = irrelevant

## RAG 06-0 5-82

### LS194

### - 4 BIT BI-DIRECTIONAL SHIFT REGISTER

- POSITIVE <u>EDGE</u> TRIGGERING (个)

- 4 MODES OF OPERATION: (A) PARALLEL LOAD

- (A) PARALLEL LOAD
  (B) SHIFT RIGHT (QA TO QD)
  (C) SHIFT LEFT (QD TO QA)
  (D) INHIBIT CLOCK (DO NOTHING)
- Parallel Inputs and Outputs
- Four Operating Modes: Synchronous Parallel Load Right Shift Left Shift Do Nothing
- Positive Edge-Triggered Clocking
- Direct Overriding Clear

| TYPE           | TYPICAL<br>MAXIMUM<br>CLOCK<br>FREQUENCY | TYPICAL<br>POWER<br>DISSIPATION |
|----------------|------------------------------------------|---------------------------------|
| 194            | 36 MHz                                   | 195 mW                          |
| LS194A         | 36 MHz                                   | 75 mW                           |
| <b>'</b> \$194 | 105 MHz                                  | 425 m₩                          |

SN74184, SN74LS194A, SN74S184 ... J OR N PACKAGE (TOP VIEW)



### description

These bigirectional shift registers are designed to incorporate virtually all of the features a system designer may want in a shift register. The circuit contains 46 equivalent gates and features parallel inputs, parallel outputs, right-shift and left-shift serial inputs, operating-mode-control inputs, and a direct overriding clear line. The register has four distinct modes of operation, namely:

Parallel (broadside) load Shift right (in the direction  $Q_A$  toward  $Q_D$ ) Shift left (in the direction  $Q_D$  toward  $Q_A$ ) Inhibit clock (do nothing)

Synchronous parallel loading is accomplished by applying the four bits of data and taking both mode control inputs, S0 and S1, high. The data are loaded into the associated flip-flops and appear at the outputs after the positive transistion of the clock input. During loading, serial data flow is inhibited.

Shift sight is accomplished synchronously with the rising edge of the clock pulse when S0 is high and S1 is low. Serial data for this mode is entered at the shift-right data input. When S0 is low and S1 is high, data shifts left synchronously and new data is entered at the shift-left serial input.

Clocking of the flip-flop is inhibited when both mode control inputs are low. The mode controls of the SN54194/SN74194 should be changed only while the clock input is high.

|       |     |     |       |       | FUNCTIO | DN T. | ABLE |      |   |     |          |      |     |                                                 |
|-------|-----|-----|-------|-------|---------|-------|------|------|---|-----|----------|------|-----|-------------------------------------------------|
|       |     |     |       | INPUT | s       |       |      |      |   | ]   | OUT      | PUTS |     | H = high level (steedy state)                   |
|       | MC  | 3DC |       | SEI   | RIAL    | 1     | PARA | LLEI |   |     | <u>,</u> |      |     | L = low level (stordy state)                    |
| CLEAR | \$1 | so  | CLOCK | LEFT  | RIGHT   | A     | 8    | C.   | 0 | UA. | 08       | αc   | 40  | X = irrelevant lany input, including tran       |
| L     | X   | x   | x     | X     | x       | X     | x    | x    | × | L.  | L        | L    | L   | * = transition from low to high level           |
| н     | ×   | X   | L     | x     | x       | x     | x    | x    | x | QAD | OBO      | QCD  | 000 | a, b, c, d = the level of steady-state input at |
| н     | н   | н   | ,     | ×     | x       | 4     | ъ    | c    | đ |     | Ð        | c    | đ   | inputs A, B, C, or D respectively.              |
| н     | L   | н   | 7     | x     | н       | ×     | x    | x    | x | н   | QAn      | QBn  | OCn | Gg. CC, or CD, respectively, before the         |
| H     | L   | н   | ,     | ×     | L       | ×     | x    | x    | × | L   | QAn      | QBn  | QCn | indicated steady-state input conditions         |
| н     | н   | L   | ,     | н     | x       | X     | x    | x    | x | Qgn | QCn      | QDn  | н   |                                                 |
| н     | н   | L   | •     | L     | x       | ×     | x    | x    | × | 080 | QCn      | QOn  | £.  | Gq, Qr, respectively, before the most           |
| н     | L   | ι   | x     | x     | x       | ×     | x    | x    | × | QAO | 080      | aco  | 000 | recent E transition of the clock                |

Fig. 32



RAMTRAP REV. B





- 2) LOW 3) HIGH IMPEDANCE G IS ENABLE ACTIVE - LOW
- '1-WAY COMMUNICATION' '3 STATE OUTPUT': 1) HIGH
- 'NON-INVERTING'
- 'OCTAL (8) BUS DRIVER'

INPUT/OUTPUT/ENABLE

INPUT

- OCTAL (8) BUS DRIVER'
- 'NON-INVERTING '
- '2-WAY COMMUNICATION'
- '3-STATE OUTPUT' 1) HIGH

LOW

- HIGH IMPEDANCE
- G IS ENABLE..ACTIVE LOW
- DIR IS DIRECTION CONTROL A→ B...B→ A

2)

3)





### TYPE SN74LS362 (TIM9904) FOUR-PHASE CLOCK GENERATOR/DRIVER





Fig. 35

114

# FOUR-PHASE CLOCK GENERATOR/DRIVER

electrical characteristics over recommonded operating frèe-air temperature rango (unless otherwise noted)

Ł

|          |                           | the second s |                                                 |               |       |        |              |     |
|----------|---------------------------|----------------------------------------------------------------------------------------------------------------|-------------------------------------------------|---------------|-------|--------|--------------|-----|
| HI A     | Hush tevel inquit willage |                                                                                                                |                                                 |               | ~     |        |              | >   |
|          | t aw level                | f f U                                                                                                          |                                                 |               |       |        | 99           | :   |
| 11       | input voltage             | OSCIN                                                                                                          |                                                 |               |       |        | 80           | >   |
| -11 - 11 | Hymereur                  | f f 0                                                                                                          |                                                 |               | 10    | 80     |              | >   |
| <br K    | Input clamp wittage       |                                                                                                                | VCC . 4 76 V. VDD . 11 4 V. 11 -                | - 18 mA       |       |        | -15          | >   |
|          | High level                | 01. 02. 63. 64                                                                                                 | VCC - 4 75 V.                                   | A = 100 = - 1 | VDD-2 | VDD-15 | VDD          | >   |
|          | autput voltage            | Other Dutputs                                                                                                  | VDD - 11 4 V to 12 6 V                          | Au 001 1      | 11    | + C    |              | •   |
|          | laud to the               | 01. 02. c.l. of                                                                                                | 10,                                             | • • m •       |       | 0.75   | 04           |     |
| vor      | Contract and the          | (http://www.                                                                                                   | VCC . 4 76 V. VDB . 11 4 V 101                  | ¥10 F .       |       | 0.25   | 04           | ¥ u |
|          |                           |                                                                                                                | 101                                             | · R mA        |       | 0.35   | 90           |     |
|          | Input current at          | <b>F</b> FU                                                                                                    |                                                 |               |       |        | 10           | -   |
| -        | maximum input voltage     | OSCIN                                                                                                          | 10 A 871 - 00 A 10 - 00 - 00 - 00 - 00 - 00 - 0 | • 5 5 V       |       |        | C 0          | É_  |
|          | High level                | FF 0                                                                                                           |                                                 |               |       |        | 20           | •   |
| =        | input current             | OSCIN                                                                                                          | ACC - 9 79 A. ADD - 17 9 A. A.                  | > > > >       |       |        | 60           | 5   |
|          | Law level                 | F F D                                                                                                          |                                                 |               |       |        | 10-          |     |
| Ŧ        | Input current             | OSCIN                                                                                                          | - 14 'A 8 71 - 004 'A 67 6 - 334                |               |       |        | <u>د د -</u> | Ě   |
|          | Shart cucuit              | All encept                                                                                                     |                                                 |               | 5     |        |              |     |
| 50       | putput current            | al. 02. 63, 64                                                                                                 | A 67 6 - 20A                                    |               |       |        |              | Ē   |
|          | Sunday survey have V      |                                                                                                                | VCC + 5 25 V. FFD and OSCIN at 0                | GND.          |       | 101    |              |     |
|          |                           |                                                                                                                | Culture of the                                  |               |       | 2      | 2            | ſ   |
|          | Current free Vor          |                                                                                                                | VCC • 5 25 V. VOD • 12 6 V.                     |               |       | 1      | 40           | 1   |
| 00       |                           |                                                                                                                | FED and OSCIN at GND. Out                       | Date Open     |       | 2      | 5            | ſ   |

4-11, picel values are st V<sub>CC</sub> + 8 V, V<sub>DD</sub> + 12 V, 1<sub>A</sub> + 26<sup>°</sup> C Net more than one autour should be strated as a time, and duration of the thest detuit should hat exceed ane tecond. Outputs 01, 02, 03, and 04 do not have short circuit protection. ÷

= 48 MHz see fig • twitching characteristics. TA = 25°C. VCC1 = 5 V. VCC2 = 12 V

| LINI            | 4144                              | MIL                       | ē                        | ē                       | ž                      | ε                              | ē                             | ĩ                             | ĩ                             | E                              | Ē                             | ĩ                              | ŧ                             | ē                              | 5                                   | ē                                   | ž                                      | Ξ                                        | ŧ                                | ē                                    |
|-----------------|-----------------------------------|---------------------------|--------------------------|-------------------------|------------------------|--------------------------------|-------------------------------|-------------------------------|-------------------------------|--------------------------------|-------------------------------|--------------------------------|-------------------------------|--------------------------------|-------------------------------------|-------------------------------------|----------------------------------------|------------------------------------------|----------------------------------|--------------------------------------|
| MIN TYP MAX     |                                   |                           | , (CC                    | 10 20                   | 10 20                  | 4()                            | 0 5 15                        | 0 6 15                        | 0 S 15                        | 0 5 15                         | 68 0/                         | CH 0/                          | C8 0/                         | 00 00                          | 8-                                  | - 19                                | 1-                                     | - 13                                     | ş-                               | -13                                  |
| 1657 CONDITIONS |                                   |                           |                          |                         |                        |                                |                               |                               | _                             | Output loads.                  | +1, e3, s4 100 µF to GND      | 62- 200 pF to GND              | Others, RL + 2 kB,            | CL - 15 pf                     | See Note 2                          |                                     |                                        |                                          |                                  |                                      |
| PARAMELER       | Output frequency, any o or of 114 | Outline Lienvency, OSCOUT | Evels time, any o putput | Rise time, any o output | Fall time any o output | Putstwelth, any o builted high | Detay time, of tow to of high | Detay time, 42 kiw in 03 high | Detay time of time to of high | Delay line, of live to of high | Delay time of high to of high | Detay tune, of high to of high | Detay time of high to of high | Delay tune, of high to of high | Delay Linie C., high to C., 111 tow | Delay time, cin tow to on 1 11 high | Delay time, c.3 kiw to FFO putput high | Delay time, c.J kiw to P.F.O. output how | Detay time, a low to OSCOUT high | Detay time, F.F.Q.Ligh to OSCOUT tow |
|                 | 1 out                             | lout                      | 16101                    | 4444                    | N IN                   | which .                        | 1011 6211                     | 1100 1201                     | 140 11-1                      | 10.11.011                      | 1011. 0211                    | 1521, 031                      | 1501 041                      | 10-411 ON1                     | 1citi o 11                          | 1-1 - 0111                          | 15.11.011                              | 10, 11,1                                 | 1:1, 05011                       | 1050 11-1                            |

LS <u>373</u>

.

- OCTAL (8) D-TYPE LATCHES
- 3 STATE OUPUT: 1) HIGH
  - 2) LOW
  - 3) HIGH IMPEDANCE
- WHEN G (ENABLE) IS HIGH, THEN Q (INPUT) WILL FOLLOW D (INPUT)
- WHEN G (ENABLE) IS LOW, THEN Q (OUTPUT) WILL LATCH D (INPUT)



| OUTPUT<br>CONTROL | ! {   | ENABLE<br>G | D | OUTPUT         |
|-------------------|-------|-------------|---|----------------|
| L                 | !     | Н           | Н | H              |
| L                 | !     | Η           | L |                |
| L                 | : ! 1 | L           | Х | Q <sub>0</sub> |
| Н                 |       | Х           | Х | HI = Z         |

 $Q_0 = DATA PRESENT AT INPUT WHEN ENABLE WENT LOW$ 

X = DON'T CARE

## 4115 DYNAMIC RAM

- 16,384 X 1 ORGANIZATION
- 3 STATE OUTPUTS
- AO A6 ADDRESS INPUTS
- CAS COLUMN ADDRESS STROBE
- D DATA INPUT
- Q DATA OUTPUT
- RAS ROW ADDRESS STROBE
- WWW. WRITE ENABLE
- REFRESH MUST BE PERFORMED EVERY 2 MILLISECONDS
- RAS LATCHES THE ROW ADDRESS (A0 AS)
- CAS LATCHES THE COLUMN ADDRESS (AU AG)

| AO   | <u>A1</u> | A2   | A3   | <u>A4</u> | A5  | A6  | 1 | AU | A1 | _A2 | A3 | <u>A</u> 4 | A5 | AS |  |
|------|-----------|------|------|-----------|-----|-----|---|----|----|-----|----|------------|----|----|--|
| 8192 | 4096      | 2048 | 1024 | 512       | 256 | 128 |   | 54 | 32 | 16  | 8  | 4          | 2  | 1  |  |
|      |           | C    | AS   |           |     |     |   |    |    | R   | AS |            |    |    |  |

4116 RAM (CONT.)

.



|       | PIN NOMEN             | CLATUR | E                  |
|-------|-----------------------|--------|--------------------|
| A0-A6 | Address Inputs        | w      | Write Enable       |
| CAS   | Column address strobe | Vee    | -5-V power supply  |
| D     | Data input            | Vcc    | +5-V power supply  |
| Q     | Data output           | VDD    | +12-V power subply |
| RAS   | Row address strobe    | VSS    | 0 V ground         |



read cycle timing

MF 4732 ROMS

- 0 4096 X 8 BIT MEMORY SIZE
- o +5, GND ONLY
- 0 8 BIT TRI-STATE DATA OUTPUTS (Q1-Q8) Q8 = MSB Q1 = LSB
- o 12 ADDRESS LINES (AU-A11) A11 = MSB AU = LSB
- O CHIP IS ENABLED WHEN CS1 AND CS2 ARE BOTH LOW
- O ONLY DURING THE ENABLE ARE THE OUTPUTS ENABLED, ALL OTHER CASES THE OUTPUTS ARE TRI-STATED.



6810 RAM

- o 128 X 8 STATIC RAM
- o USED AS SCRATCH PAD (CPU RAM)
- O TWO DEVICES ARE USED TO MAKE A 128 X 15 MEMORY AREA
- o + 5, GND ONLY

| PIN   | မားအရဲ       | YM ()H     | ۲           |
|-------|--------------|------------|-------------|
| ۰đc   | ~0           | Vcc        | 3 94        |
| 2 00  | •            | A0         | 323         |
| ۶do   | 1            | - A1       | 212         |
| ۰ do  | 3            | A2         | 2 2 1       |
| ۰þ    | 3            | <b>A</b> 3 | <b>b</b> 30 |
| • do  | H.           | <b>A</b> 4 | 119         |
| 7 de  | <b>76</b>    |            | 1 18        |
| • de  | <b>&gt;6</b> | **         | ייל         |
| • de  | 57           | 98 / Yev   | 3 16        |
| e de  | 30           | ದ್ರ        | þ.          |
| n da  | 31           | 54         | þ، ط        |
| uz da | 32           | ສາ         | 613         |

DO - D7 = DATA I/O  $AO_- A6 = ADDRESS LINES$  R/W = HIGH IS READ, LOW IS WRITE TO BE ENABLED: CSO & CS3 MUST BE HIGH  $\overline{CS1, CS2, CS4}, & \overline{CS5} MUST BE LOW$ 

Fig. 39

RAG 05-03-82

| D4-          |      | -vss   | D12-  |          | -VSS   |                                       | TMS 9900 PIN ASSIGNM | AENTS                   |
|--------------|------|--------|-------|----------|--------|---------------------------------------|----------------------|-------------------------|
| D3-          |      | -05    | D11-  |          | -013   | Vaa                                   | 1                    |                         |
| D2-          |      | -D6    | P10-  |          | -D14   | Vcc                                   | 2 20                 | 53 MEMEN                |
| D1-          | U610 | -07    | D9-   | U611     | -D15   | WAIT                                  | 3                    | E 62 READY              |
| D0-          |      | -A14   | DS-   |          | -A14   | LOAD                                  | ▲ <<                 | 51 61 WE                |
| A3-          | 4732 | -A13   | A3-   | 4732     | ⊢A13   | HOLDA                                 | s 💭                  | 50 CRUCLK               |
| A4-          |      | -A12   | A4-   |          | -A12   | RESET                                 |                      | E 59 Vcc                |
| *CS1-        |      | -A11 + | *CS1- |          | -A11   | ¢1                                    | • 20                 | 1 58 AC                 |
| VSS-         |      | -A10   | vss-  |          | -A10   | \$2                                   | •                    | 56 015                  |
| A5-          |      | -A9    | A5-   |          | -A9    | A14 1                                 |                      | 2 55 D14                |
| A6-          |      | -AB    | A6-   |          | -A3    | A13 0                                 |                      | 54 013                  |
| VCC-         | *    | HA7    | VCC-  | *        | -A7    | A11 1                                 |                      | H 52 011                |
|              |      | -      |       |          |        | A10 1                                 |                      | 51 010                  |
|              |      |        |       |          |        | A9 1                                  |                      | 50 09                   |
|              |      |        |       |          |        | AS 1                                  |                      |                         |
|              |      | _      |       |          |        | A6 1                                  |                      | 47 08                   |
| VCC-         |      | Hvee   | vcc-[ |          | -788   | _ AS 1                                | • ⊭                  | C 46 05                 |
| VSS-         |      | -*CS1  | VSS-  |          | -*CS1  | A4 2                                  |                      | C 45 D4                 |
| VSS-         |      | -vss   | VSS-  |          | -vcc   | AJ 2                                  |                      | <b>H</b> <sup>4</sup> m |
| *₩E-         | U603 | -07    | *WE-  | U609     | -D12   | A1 2                                  |                      | 43 02                   |
| A14-         |      | -02    | A14-  |          | -013   | AQ 2                                  | *                    |                         |
| A13-         | 4810 | -04    | A13-  | 6810     | -014   | . ♦< 2                                | s 🖒                  | 40 V55                  |
| A12-         |      |        | A12-  |          | -D15   | V <sub>SS</sub> 27                    |                      | 239 NC                  |
| A11-         |      | Los    | A11-  |          | -DS    | • • • • • • • • • • • • • • • • • • • |                      | H 38 NC                 |
| Δ10-         |      |        | A10-  |          | -09    | DBIN 25                               | , <del>Z</del>       |                         |
| Δ9-          |      | n1     | 69-   |          |        | CRUOUT 30                             | o €‡                 | 315 101                 |
| Δ <u>3</u> - |      |        | A3-   |          | -011   | - CRUIN 31                            |                      | 34 102                  |
| VCC-         | *    | LUCE   | VCC-  | *        | Luce   | INTREQ 32                             | ² <sup>5</sup> -i !  |                         |
| VCC          |      | 1.0.0  | VCC L | <u> </u> | 1 100  |                                       |                      |                         |
|              |      |        |       |          |        |                                       |                      |                         |
|              |      |        |       |          |        |                                       |                      |                         |
|              |      |        |       |          |        |                                       |                      |                         |
| d0-          |      | -vss 👘 | *QC-  |          | -VSS   | DS                                    | -vss                 |                         |
| d1-          |      | -00-   | 09-   |          | -08    | d1-                                   | -40                  |                         |
| d2-          | UG14 | -01    | d1-   | U615     | -d0    | D10- U                                | 616 -09              |                         |
| d3-          |      | -02    | 43-   |          | -d2    | 43-                                   | -d2                  |                         |
| d4-          | 74LS | нoз    | D11-  | 74LS     | -010   | B12- 74                               | 4LS -D11             |                         |
| d5-          | -245 | -04    | D13-  | -373     | -D12   | d5:                                   | 244 - 14             |                         |
| <b>d</b> 6-  | ÷    | -05    | d5-   |          | -d4    | D14-                                  | -D13                 |                         |
| d7-          | 4    | -D6    | d7-   |          | -d6    | d7-                                   | - 16                 |                         |
| *DIOG-       |      | -ם7    | D15-  |          | -D14   | *DOG-                                 | -015                 |                         |
| VCC-         | *    | -DBIN  | vcc-  | *        | -*DING | vcc-                                  | * -*DOG              |                         |
|              |      | 1      |       |          | •      |                                       |                      |                         |

÷

\_

. .

D denotes 16 bit data bus d denotes 3 bit multiplexed data bus

Fig. 40



TI-99/4A LOGIC BOARD COMPONENT LOCATION DIAGRAM

719 41

122



FIGURE 43 TI-99/4 SYSTEM BLOCK DIAGRAM



124

مب











TI-99/4A CONS 5 POWER SUPPLY

64 Evé



130

FIGURE 50 TI-99/4A SYSTL BLOCK DIAGRAM



.

TI-99/4A S: 1A

IATIC



.

£13 52 TI-99/4A SCHEMATIC

132

.



1.99/4A [...4EMATIC

~



134

TI-99/4A SCHEMATIC DIAGRAM

fig 51




