

# Section 7 Display/Terminal Management Processor (TMP)

From: ftp://bitsavers.informatik.uni-stuttgart.de/components/national/\_dataBooks/1988\_National\_Microcontrollers\_Databook.pdf



# **Section 7 Contents**

| ТМР                                                        | 7-3  |
|------------------------------------------------------------|------|
| NS405 Series Display Terminal Management Processor (TMP)   | 7-4  |
| AB-14 Throughput Considerations in NS405 System Planning   | 7-43 |
| AB-16 NS405-Series TMP External Interrupt Processing       | 7-44 |
| AN-354 TMP Row and Attribute Table Lookup Operation        | 7-46 |
| AN-355 TMP-Dynamic RAM Interfacing                         | 7-53 |
| AN-367 TMP External Character Generation                   | 7-58 |
| AN-369 NS405 TMP Logic Analyzer                            | 7-61 |
| AN-374 Building an Inexpensive But Powerful Color Terminal | 7-68 |
| AN-399 TMP Extended Program Memory                         | 7-73 |

# National Semiconductor

# **ТМР**ТМ

# **Terminal Management Processor**

The TMP (NS405 series) is a single-chip CRT terminal display controller. The TMP is supported by the MOLE™ development system and replaces all the following LSI circuits commonly found in a terminal:

- Microprocessor
- Program ROM
- 64 x 8 RAM
- CRT controller
- DMA controller
- Character generator
- UART
- BAUD rate generator
- Parallel I/O controller
- Timer

The TMP offers complete CRT control over a wide scope of high-density circuit applications including phones, keyboard integration assignments, logic analyzers and more.

The NS455 Terminal Management Processor (TMP) demo board is available for design support.

Highly compact, the TMP board reduces previously necessary board space dramatically while providing 100% emulation of a classic low-end terminal. The board can also be used for TMP evaluation or as a vehicle for designing-in the NS405 device. INE

The board which is controlled by a preprogrammed NS455, needs only a video monitor, ASCII encoded keyboard, and power supply to provide your complete terminal. Should you wish to write your own program, no problem.

The cross-assembler software provides the capability. The board will execute custom programs through up to 8k of offchip memory.

The TMP demo board comes complete with operating manual, program source listing, board schematic, board layout, and all necessary connectors.

When you're ready to design your own TMP system, turn to National's MOLE development system. By using this system-comprised of brain board, personality board and software—you bring dedicated development support to the TMP chip, making design-in extremely fast and simple.

7-3

# PRELIMINARY

# National Semiconductor

# NS405-Series Display/Terminal Management **Processor (TMP)**

# **General Description**

The NS405 is a CRT terminal controller on a chip. It is a microcomputer system which replaces the following LSI circuits commonly found in a CRT data terminal:

- Microcomputer
- Baud Rate Generator
- CRT Controller
- Interrupt Controller Parallel I/O Controller
- DMA Controller
- Character Generator
- UART

In addition the NS405 includes powerful attribute logic, two

Timer

graphics display modes, and fast video output circuits.

The NS405 is primarily intended for use in low-cost terminals, but contains many features which make it a superior building block for "smart" terminals and word processing systems.

The NS405 interfaces easily to the display monitor, keyboard, display memory, and I/O ports. The architecture and instruction set are derived from the 8048-series microcontrollers. The instruction set has been enhanced and the architecture tailored to allow the NS405 CPU to efficiently manage a large display memory and an extensive interrupt environment.

The TMP can be used to easily and inexpensively add a display to many systems where it was previously impractical, it is not limited to terminal applications.

**Block and Connection Diagrams** 

# Features

- Enhanced 8048 instruction set and architecture
- Up to 8k x 8 ROM external with ROM expand bus
- On-board RAM 64 x 8
- Programmable display format
- On-board video memory management unit
- 16-bit bidirectional display memory bus (direct video and attribute RAM interface)
- Built-in timer
- Real-time clock (may be programmed for 1 Hz)
- Video control signals
- Eight independent attributes
- Pixel and block graphics display modes
- Programmable cursor characteristics
- Programmable CRT refresh rate
- Light pen feature
- UART, programmable baud rate up to 19.2k baud
- Character generator (128 characters 7 x 11 max)
- Single 5-volt supply @ 110 mA (typ)
- Up to 18 MHz video dot rate (12 MHz CPU clock)
- 48-pin package
- 8-bit parallel I/O port (multiplexed with external ROM)
- Extensive I/O expansion capabilities
- Up to 64k by 8 or 16 video RAM





7-4

# Absolute Maximum Ratings

If Military/Aerospace specified devices are required, contact the National Semiconductor Sales Office/ Distributors for availability and specifications.

| Temperature Under Bias            | 0°C to +70°C    |
|-----------------------------------|-----------------|
| Storage Temperature               | -65°C to +150°C |
| All Input or Output Voltages      |                 |
| with Respect to V <sub>SS</sub> * | -0.5V to +7.0V  |

# Power Dissipation ESD

\*EA, SI and VSYNC may be subjected to V<sub>SS</sub> + 15V.

Note: Absolute maximum ratings indicate limits beyond which permanent damage may occur. Continuous operation at these limits is not intended; operations should be limited to those conditions specified under DC Electrical Characteristics.

# **DC Electrical Characteristics**

 $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ ,  $V_{CC} = +5V \pm 10^{\circ}$ ,  $V_{SS} = 0V$ , unless otherwise specified

| Symbol           | Parameter                                                        | Test Conditions                       | Min  | Max             | Units |
|------------------|------------------------------------------------------------------|---------------------------------------|------|-----------------|-------|
| V <sub>IL1</sub> | Input Low Voltage (All Except XTAL1, XTAL2, RESET)               |                                       | -0.5 | 0.8             | V     |
| V <sub>IH1</sub> | Input High Voltage (All Except XTAL1, XTAL2, RESET)              |                                       | 2.0  | V <sub>CC</sub> | V     |
| VIL2             | Input Low Voltage (XTAL1, XTAL2, RESET)                          |                                       | -0.5 | 0.6             | V     |
| V <sub>IH2</sub> | Input High Voltage (XTAL1, XTAL2, RESET)                         |                                       | 3.8  | Vcc             | V     |
| VOL              | Output Low Voltage (All Except INTENS, VO)                       | I <sub>OL</sub> = 2.0 mA              |      | 0.4             | V     |
| V <sub>OH</sub>  | Output High Voltage (All Except INTENS, VO)                      | I <sub>OH</sub> =125 μA               | 2.4  | Vcc             | v     |
| VOL              | Output Low Voltage (INTENS, VO)                                  | I <sub>OL</sub> = 5.0 mA              |      | 0.4             | V     |
| V <sub>OH</sub>  | Output High Voltage (INTENS, VO)                                 | I <sub>OH</sub> = −500 μA             | 2.4  |                 | V     |
| l <sub>IL</sub>  | Input Leakage Current (EA, INT, SI)                              | $V_{SS} \le V_{IN} \le V_{CC}$        |      | ±10             | μΑ    |
| lol              | Output Leakage Current<br>(ROM Expand Bus, High Impedance State) | $V_{CC} \ge V_{IN} \ge V_{SS} + 0.45$ |      | ±10             | μΑ    |
| lol              | Output Leakage Current<br>(System Bus, High Impedance State)     | $V_{CC} \ge V_{IN} \ge V_{SS} + 0.45$ |      | ±100            | μΑ    |
| Icc              | Total Supply Current                                             | T <sub>A</sub> = 25°C                 |      | 150             | mA    |

# **AC Electrical Characteristics**

 $T_A = 0^{\circ}C$  to +70°C,  $V_{CC} = +5V \pm 10\%$ ,  $V_{SS} = 0V$ , unless otherwise specified

| Symbol                      | Parameter                                             | Min  | Max   | Units |  |  |
|-----------------------------|-------------------------------------------------------|------|-------|-------|--|--|
| I AND ROM EXPAND BUS TIMING |                                                       |      |       |       |  |  |
| F <sub>XTAL</sub>           | Crystal Frequency                                     | 3    | 18    | MHz   |  |  |
| FCPU                        | CPU Frequency                                         | 3    | 12    | MHz   |  |  |
| t <sub>CY</sub>             | CPU Cycle Time                                        | 1.25 | 7.5   | μs    |  |  |
| t <sub>DF</sub>             | Video Dot Time                                        | 55.5 | 333.3 | ns    |  |  |
| tLL                         | ALE Pulse Width (Note 1)                              | 125  |       | ns    |  |  |
| t <sub>AL</sub>             | Address Setup to ALE (Note 1)                         | 55   |       | ns    |  |  |
| t <sub>LA</sub>             | Address Hold from ALE (Note 1)                        | 40   |       | ns    |  |  |
| t <sub>CC</sub>             | Control Pulse Width PSEN, RD (Note 1)                 | 250  |       | ns    |  |  |
| t <sub>DR</sub>             | Data Hold (Notes 1, 4)                                | 0    | 100   | ns    |  |  |
| t <sub>RD</sub>             | PSEN, RD to Data In (Note 1)                          |      | 220   | ns    |  |  |
| t <sub>AD</sub>             | Address Setup to Data In (Note 1)                     |      | 360   | ns    |  |  |
| tAFC                        | Address Float to RD, PSEN (Notes 1, 5)                | 0    |       | ns    |  |  |
| t <sub>CAF</sub>            | PSEN to Address Float (Notes 1, 5)                    | -10  | + 10  | ns    |  |  |
| t <sub>DAL</sub>            | Data Setup to ALE (RE0-7, 11, 12) (Note 1)            | 55   |       | ns    |  |  |
| t <sub>ALD</sub>            | Data Hold from ALE (RE0-7, 11, 12) (Note 1)           | 40   |       | ns    |  |  |
| t <sub>CIS</sub>            | Control Input Setup to ALE (RE8, 9, 10) (Note 1)      | 240  |       | ns    |  |  |
| t <sub>CIH</sub>            | Control Input Hold from ALE (RE8, 9, 10) (Notes 1, 4) | 75   | 125   | ns    |  |  |

NS405

1.5W

2000V

# **AC Electrical Characteristics**

 $T_A$  = 0°C to +70°C,  $V_{CC}$  = +5V ±10%,  $V_{SS}$  = 0V, unless otherwise specified (Continued)

| Symbol           | Parameter                                  | Min                               | Max | Units |
|------------------|--------------------------------------------|-----------------------------------|-----|-------|
| TEM BUS TIMIN    | G                                          | · · · · · ·                       |     |       |
| t <sub>EL</sub>  | RAM ALE Low Time (Note 1)                  | 250                               |     | ns    |
| t <sub>EH</sub>  | RAM ALE High Time (Note 1)                 | 100                               |     | ns    |
| tAS              | Address Setup to RAM ALE (Note 1)          | 20                                |     | ns    |
| t <sub>AH</sub>  | Address Hold from RAM ALE (Note 1)         | 10                                |     | ns    |
| t <sub>RR</sub>  | RAM RD Width (Note 1)                      | 210                               |     | ns    |
| t <sub>AR</sub>  | Address Setup to RAM RD (Note 1)           | 80                                |     | ns    |
| tRRD             | Data Access from RAM RD (Note 1)           |                                   | 140 | ns    |
| tRDR             | Data Hold from RAM RD (Notes 1, 4)         | 0 60                              |     | ns    |
| t <sub>WFI</sub> | FIFO In Clock Width (Note 1)               | 210                               |     | ns    |
| tww              | RAM WR Strobe Width (Note 1)               | 130                               |     | ns    |
| t <sub>AW</sub>  | Address Setup to RAM WR (Note 1)           | 120                               |     | ns    |
| t <sub>DW</sub>  | Data Setup to RAM WR (Note 1)              | 10                                |     | ns    |
| t <sub>WD</sub>  | Data Hold from RAM WR (Note 1)             | Data Hold from RAM WR (Note 1) 20 |     |       |
| EO TIMING        |                                            |                                   |     |       |
| t <sub>DF</sub>  | Dot Period = $\frac{1}{f_c}$ (Note 1)      | 55                                |     | ns    |
| t <sub>VID</sub> | Video Blank Time (Note 1)                  | 5                                 | 15  | ns    |
| t <sub>VI</sub>  | Skew, Intensity to Dot 0 (Note 1)          | - 15                              | 15  | ns    |
| tFOV             | FIFO Out Clock to Dot 0 (Note 1)           | 15                                |     |       |
| twFOH            | FIFO Out Clock Width High (Note 1, Note 2) | 55                                | 165 | ns    |

\*1/3 CPU cycle.

\*\*1 Dot time is 55 ns.

Note 1: Control outputs  $C_L = 80 \text{ pF}$ ; ROM Expand Bus outputs  $C_L = 150 \text{ pF}$ ; System Bus outputs  $C_L = 100 \text{ pF}$ ;  $V_{OUT}$  & INTENS outputs  $C_L \approx 50 \text{ pF}$ ;  $F_{XTAL} = 18 \text{ MHz}$ ;  $F_{CPU} = 12 \text{ MHz}$ . XTAL1 & XTAL2 driven externally per *Figure 12b* with 50% duty cycle.

Note 2: FO CLK duty cycle is shown above.

Note 3: Hold request is latched. It is honored at the start of the next vertical retrace.

Note 4: Max spec. listed for user information only, to prevent bus contention. Maximum value not tested.

Note 5: Not tested.

| Character<br>Cell Width | FIFO Out<br>HIGH | FIFO Out<br>LOW |  |  |
|-------------------------|------------------|-----------------|--|--|
| 6                       | 1 dot            | 5 dots          |  |  |
| 7                       | 2 dots           | 5 dots          |  |  |
| 8                       | 2 dots           | 6 dots          |  |  |
| 9                       | 3 dots           | 6 dots          |  |  |
| 10                      | 3 dots           | 7 dots          |  |  |

# **Input Hold Times**

 $T_A = 25^{\circ}C, V_{CC} = +5V \pm 10\%, V_{SS} = 0V$ 

| Input              | Min Active Time                                   |
|--------------------|---------------------------------------------------|
| Reset              | 50 ms (power up)<br>5 CPU Cycles (after power up) |
| External Interrupt | 2 CPU Cycle                                       |
| Light Pen          | 1 CPU Cycle                                       |
| I/O Input          | 1 CPU Cycle                                       |
| Hold Request       | 1 CPU Cycle (Note 3)                              |

# FIFO

Fall through should not be greater than 4 character times (character time =  $1/f_{XTAL} \times #dots/cell$ ).

Throughput rate must be at least the character rate (character rate = 1/character time).

| Symbol           | Parameter         | Test Conditions |                            |                                                                               | Min                                      | Max | Units   |
|------------------|-------------------|-----------------|----------------------------|-------------------------------------------------------------------------------|------------------------------------------|-----|---------|
| CIN              | Input Capacitance | Fc ≕            | 1 MHz (Note 5)             |                                                                               |                                          | 10  | pF      |
| С <sub>ОИТ</sub> | Output and Reset  | Unme            | asured Pins Returned       | to V <sub>SS</sub> (Note 5)                                                   |                                          | 20  | pF      |
|                  | trical Characteri |                 | -                          | Time                                                                          |                                          |     |         |
| Symbol           |                   | Paramete        | er                         |                                                                               | Тур                                      |     |         |
| t <sub>LL</sub>  | ALE Pulse Wi      | dth             |                            |                                                                               | 14 t <sub>CY</sub>                       | /60 |         |
| t <sub>AL</sub>  | Address Setu      | p to ALE        |                            |                                                                               | 8 t <sub>CY/</sub>                       | 60  |         |
| t <sub>LA</sub>  | Address Hold      | from ALE        |                            |                                                                               | 6 t <sub>CY/</sub>                       | 60  |         |
| tcc              | Control Pulse     | Width           | PSEN<br>RD                 | 24 t <sub>CY/60</sub><br>36 t <sub>CY/60</sub>                                |                                          |     |         |
| tCY              | CPU Cycle Ti      | me              |                            | $60 t_{CY/60} = 15/f_{CPU} = \frac{15}{f_{XTAL} \div 1 \text{ or } \div 1.5}$ |                                          |     | r ÷ 1.5 |
| t <sub>DR</sub>  | Data Hold         |                 | ······                     | -2 t <sub>CY/60</sub>                                                         |                                          |     |         |
| t <sub>RD</sub>  | Control Pulse     | to Data li      | n PSEN<br>RD               | 18 t <sub>CY/60</sub><br>30 t <sub>CY/60</sub>                                |                                          |     |         |
| t <sub>AD</sub>  | Address Setu      | p to Data       | In                         |                                                                               | 32 t <sub>CY</sub> ,                     | /60 |         |
| t <sub>AFC</sub> | Address Floa      | t to            | PSEN<br>RD                 |                                                                               | 2 t <sub>CY/</sub><br>2 t <sub>CY/</sub> |     |         |
| tCAF             | PSEN to Add       | ress Float      |                            |                                                                               | 0 t <sub>CY/</sub>                       | 60  |         |
| t <sub>DAL</sub> | Data Setup to     | ALE             | RE0–7<br>RE8–10<br>RE11–12 | 6 t <sub>CY/60</sub><br>-2 t <sub>CY/60</sub><br>16 t <sub>CY/60</sub>        |                                          |     |         |
| t <sub>ALD</sub> | Data Hold fro     | m ALE           | RE0-7<br>RE8-12            | 2 t <sub>CY/60</sub><br>6 t <sub>CY/60</sub>                                  |                                          |     |         |

#### Ticks Symbol Parameter Min Max RAM ALE Low Time 14 t<sub>CY/60</sub> - 42 ns t<sub>EL</sub> t<sub>EH</sub> RAM ALE High Time 6 t<sub>CY/60</sub> - 25 ns t<sub>AS</sub> Address Setup to RAM ALE 4 t<sub>CY/60</sub> - 60 ns Address Hold from RAM ALE 2 t<sub>CY/60</sub> - 40 ns t<sub>AH</sub> Read or Write Cycle Time **t**RCY RAM RD Width t<sub>RR</sub> 12 t<sub>CY/60</sub> - 40 ns Address Setup to RAM RD 6 t<sub>CY/60</sub> - 45 ns t<sub>AR</sub> Data Access from RAM RD $10 t_{CY/60} - 70 \text{ ns}$ tRRD Data Hold from RAM RD t<sub>RDR</sub> FIFO In Clock Width 12 t<sub>CY/60</sub> - 40 ns t<sub>WFI</sub> RAM WR Strobe Width 8 t<sub>CY/60</sub> - 27 ns tww Address Setup to RAM WR 10 t<sub>CY/60</sub> - 90 ns t<sub>AW</sub> t<sub>DW</sub> Data Setup to RAM WR 2 t<sub>CY/60</sub> - 30 ns Data Hold from RAM WR 2 t<sub>CY/60</sub> - 20 ns twp

NS405

7





NS405-Series Detailed RE12 RE11 RE10 RE9 RE8 XTAL1 XTAL2 HLDA SC CLR INTR LP HOLD EA 23 22 25 36 **I**37 38 39 29 ٦. - 6 SI RECEIVE REG. UART CONTROL INTERRUPT REG. ← TIMER ← ÷32 ← ÷15 ← r)I CLOCK ROM EXPAND OUT 40 RED, 1/00 34 ROM RECEIVE BUF. REGISTERS اجا GENERATOR INTERBUPT MASK MUX CNTL INPUT - PSEN CPU CLK 🗲 41 RE1. 1/01 EXPAND ΪP 2×8 INTERRUPT 42 RE2. 1/02 GEN'L. CONTROL 5 BAUD RATE 43 RE3, 1/03 L DOT INTR 1/0 CONTROL REGS PROGRAM COUNTER CLOCK PORT 🕈 RE4, 1/04 2×8 -8 13 BITS 44 STACK 45 RE5, 1/05 REAL ALĚ 🗕 POINTER MUX XMIT BUFFER UART TIME PSEN-+ CNTL. RAM 43 RE6, 1/06 46 RE7, 1/07 S0 **∢**33 STATUS REG. XMIT REG. INTERRUPT 64×8 8D-UART AND BAUD RATE ALU GENERATOR ALE 📣 21 FO CLK HIGH RAM ALE **18** ACCUMULATOR TIMING ACCUMULATOR , RAM WR SIGNAL EA DOT CLK 19 GENERATION RAM RD CPU CLK 20 FI CLK 17 PSEN **4**<u>30</u>⊧ RD 431 I <sub>VERT</sub> CHARACTER DISPLAY MEMORY ATTRIBUTE HORIZONTAL HORIZONTAL EOR GENERATOR LATCHES **CONTROL REGISTERS I** CONTROL SYNC CHARACTER CONTROL 7×11×128 ROM 7×16 2×8 REGISTERS → HS 28 DOT REGISTERS **4 CHARACTER** SYNC, BLANK, DISPLAY MEMORY ATTRIBUTE CLK LENGTH FIFO **CONTROL REGISTERS II** GRAPHICS LOGIC **17 BITS** 3×8 GENERATOR SCAN FO CLK VERTICAL VERTICAL CONTROL CONTROL 8 DATA SYNC **DISPLAY MEMORY** REGISTERS INTENSITY REGISTERS **8 ATTRIBUTES** CONTROL **VIDEO CONTROL** 27 VS DISPLAY SELECT 1 CURSOR REGISTER SELECT SYNC. BLANK. BLINK SELECT LOGIC LENGTH REGISTER SYSTEM CONTROL CONTROL REGISTER **CRT REFRESH AND** VIDEO CONTROL CONTROL LOGIC LOGIC/OUTPUT

26

**VIDEO OUTPUT** 

(VO)

25

INTENS/

FO CLK

4 48

Vcc

**Block Diagram** 

NS405

1-16

SB0-SB15

TL/DD/5526-7

REAL TIME INTERRUPT

**4** 32

RESET

**4** 24

Vss

# 1.0 Functional Pin Descriptions

| 1.1 SUP      | PLIES                                                  |                                                                                                                                                                                                                                                                                                                                                                |
|--------------|--------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin          | Name                                                   | Function                                                                                                                                                                                                                                                                                                                                                       |
| 48           | V <sub>CC</sub> — Power                                | 5V ±10%                                                                                                                                                                                                                                                                                                                                                        |
| 24           | V <sub>SS</sub> — Ground Reference                     |                                                                                                                                                                                                                                                                                                                                                                |
|              | JT SIGNALS                                             |                                                                                                                                                                                                                                                                                                                                                                |
| 23, 22<br>29 | XTAL1, XTAL2 — Crystal 1, 2:<br>EA — External Access:  | Crystal connections for clock oscillator (3–18 MHz).<br>Pull HIGH (V <sub>IH2</sub> )                                                                                                                                                                                                                                                                          |
| 32           | RESET                                                  | An active low input that initializes the processor. The RESET input is also used for internal ROM verification.                                                                                                                                                                                                                                                |
| 34           | SI — Serial Input:                                     | Drives receiver section of UART (true data).                                                                                                                                                                                                                                                                                                                   |
|              | PUT SIGNALS                                            |                                                                                                                                                                                                                                                                                                                                                                |
| 33           | SO — Serial Output:                                    | Driven by transmitter section of UART (true data).                                                                                                                                                                                                                                                                                                             |
| 21           | ALE — Address Latch Enable:                            | ROM address is available on the ROM Expand Bus and may be latched<br>on the falling edge of ALE. Port output data may be latched on the rising<br>edge of ALE. ALE pulses are always present, even if EA is tied low.                                                                                                                                          |
| 30           | PSEN — Program Store Enable:                           | Enable external ROM output drivers when low. <u>PSEN</u> is idle (high) when the CPU fetches from internal ROM.                                                                                                                                                                                                                                                |
| 31           | RD — Read Port Data:                                   | Accept Port input data on ROM Expand Bus RE0–RE7 while low. ROM<br>Expand Bus is in high impedance state while RD is low.                                                                                                                                                                                                                                      |
| 28           | HS — Horizontal Sync                                   | The rising edge of HS is controlled by the Horizontal Sync Begin Register<br>and the falling edge is controlled by the Horizontal Sync End Register. HS<br>is disabled (low) if bit 5 of the Video Control Register $= 0$ .                                                                                                                                    |
| 27           | VS — Vertical Sync Output:                             | The falling edge of $\overline{VS}$ is controlled by the Vertical Sync Begin Register<br>and the rising edge is controlled by the Vertical Sync End Register. $\overline{VS}$ is<br>at TRI-STATE if bit 5 of the Video Control Register = 0.                                                                                                                   |
| 26           | VO — Video Output:                                     | High = beam on, low = beam off. VO is disabled (low) if bit 5 of the<br>Video Control Register = 0.                                                                                                                                                                                                                                                            |
| 25           | INTENS/FO CLK                                          | (Shared pin) INTENS Signal under attribute control may be used to switch<br>the bistable brightness of display characters.<br>FIFO Out Clock may be used to clock data from an external FIFO in<br>synchronism with data from the internal FIFO.                                                                                                               |
| 17           | VID CLK/FI CLK — Video Dot Clock Out/<br>FIFO IN CLOCK | Both CANNOT be used simultaneously.<br>(Shared pin) The rising edge of the Video Dot Clock may be used to clock<br>the data out of the video output pin. FIFO In Clock may be used to clock<br>data from an extended attribute RAM into an external FIFO in<br>synchronism with the data loaded into the internal FIFO.<br>Both CANNOT be used simultaneously. |
| 18           | RAM ALE — RAM Address Latch Enable:                    | RAM address is available on the System Bus and may be latched on the<br>falling edge of RAM ALE. Only operational when Display RAM accesses<br>being performed. Otherwise high.                                                                                                                                                                                |
| 20           | RAM RD RAM Read:                                       | Enable display RAM data onto the System Bus when RAM RD is low.                                                                                                                                                                                                                                                                                                |
| 19           | RAM WR — RAM Write:                                    | Data to RAM is available on the System Bus and may be written at the                                                                                                                                                                                                                                                                                           |
|              |                                                        | rising edge of RAM WR.                                                                                                                                                                                                                                                                                                                                         |
| 1.4 BUS      |                                                        |                                                                                                                                                                                                                                                                                                                                                                |
| 1–8          | SB0-SB7 — System Bus 0-7:                              | Display RAM address is output while RAM ALE is high and may be<br>latched on the falling edge of RAM ALE. System Bus accepts data input<br>while RAM RD is low and outputs data while RAM WR is low.                                                                                                                                                           |
| 9–16         | SB8-SB15 — System Bus 8-15:                            | Normally, Display RAM address is output and held on these pins for the full read or write cycle. However, if bit 4 of the System Control Register is set, these pins function bidirectionally like SB0–SB7 to allow 16-bit data words for attribute operation.                                                                                                 |
| 35–47        | RE0-12 — ROM Expand Bus 0-12:                          | Used for program ROM expansion as described below. Time multiplexed with I/O port and system control signals. I/O port and system control signals only if no external ROM used.                                                                                                                                                                                |
| 40–47        | RE0-RE7                                                | Low order ROM address is output and may be latched on the falling edge of ALE. Enable ROM data to this Bus when $\overrightarrow{\text{PSEN}}$ is low. Enable I/O port input data to the Bus when $\overrightarrow{\text{RD}}$ is low. Use the rising edge of ALE to latch port output data.                                                                   |

| 1.0 Fu | 1.0 Functional Pin Description (Continued) |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
|--------|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Pin    | Name                                       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
| 39–35  | RE8-RE12                                   | Five most significant bits of the ROM address are output during ALE and remain stable until data is read in during PSEN. These pins are multiplexed with the HLDA, INTR, IP, SC CLR, and HOLD signals.                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |
| 37     | INTR — Interrupt: RE10                     | An active low input that interrupts the processor if the external interrupt is<br>enabled. Because it shares a pin with RE10, INTR may be driven directly<br>only if no external ROM is used (EA is low). Otherwise must be driven<br>through a 3.9k resistor.*                                                                                                                                                                                                        |  |  |  |  |  |  |  |
| 38     | IP — Light Pen Interrupt: RE9              | An active low input that interrupts the processor if internal interrupts are<br>enabled and bit 5 in the Interrupt Mask Register is set. Because it shares<br>a pin with RE9, LP may be driven directly only if EA is low. Otherwise,<br>must be driven through a 3.9k resistor.*                                                                                                                                                                                      |  |  |  |  |  |  |  |
| 39     | HOLD — HOLD request: RE8                   | When high, requests that the NS405 enter the Hold mode. When in the<br>Hold mode the System Bus will be in a high impedance state. The Hold<br>mode is granted at the beginning of the next vertical retrace. Because it<br>shares a pin with RE8, HOLD may be driven directly only if EA is low.<br>Otherwise, must be driven through a 3.9k resistor.*                                                                                                               |  |  |  |  |  |  |  |
| 35     | HLDA — Hold Acknowledge: RE12              | This output is asserted in response to Hold and provides handshake capability with another processor (active high). For more detailed information see Section 3.0 Slave Processing. Because HLDA shares a pin with RE12, the HLDA state is preset only during the interval preceding the rising edge of ALE. However, if no external ROM is used, HLDA is a steady state output and need not be latched externally.                                                    |  |  |  |  |  |  |  |
| 36     | SC CLR — Scan Count Clear: RE11            | This output clears an external scan counter when used with an external character generator. It is a low going pulse which occurs during the horizontal retrace preceding the first scan line of each character row. Because SC CLR shares a pin with the RE11, the correct SC CLR state is present only during the interval preceding the rising edge of ALE. However, if no external ROM is used, SC CLR is a steady state output and need not be latched externally. |  |  |  |  |  |  |  |

\*Unused control inputs must be terminated

**NS405** 

# 2.0 Functional Description 2.1 CPU

The CPU of the NS405 is patterned after the 8048 single chip microcomputer (see *Figure 1*).



7-12

# 2.1.1 Accumulator — High Accumulator

In addition to the regular 8-bit Accumulator, there is an 8-bit High Accumulator extension to facilitate the 16-bit operations required for display memory management. The HACC/ ACC pair is usually used in conjunction with the 16-bit RAM pointer registers (RA, R0 and RB, R1, CURSOR, HOME, BEGD and ENDD) to effect video data transfers. In addition, external attribute memory is loaded in a 16-bit transfer operation. Any instruction which causes a carry or borrow out of the low accumulator will affect the high accumulator (see *Figure 2*).

Auxiliary carry is used only when converting the accumulator contents from binary to BCD (binary coded decimal) using the DA A instruction. The auxiliary carry flag can be cleared by moving a zero into bit 6 of the program status word.



**FIGURE 2. CPU Accumulator** 

# 2.1.2 Program Counter (PC)

The Program Counter is a 13-bit wide register which provides program addressing for the CPU. The lower 11 bits operate like a conventional program counter while the upper 2 bits are actually latches. These 2 latches are automatically loaded from the bank select flip-flops (PSW bits 3, 4) whenever a JMP or CALL instruction is executed. The bank select flip-flops in turn are only modified upon the execution of a Select Memory Bank Instruction or modification of the PSW (see *Figure 3*).



BANK SELECT BITS (LATCHES) (LOADED BY EXECUTION OF JMP OR CALL)

TL/DD/5526-10

#### FIGURE 3. TMP Program Counter

#### 2.1.3 Program Memory

Memory is subdivided into 2k banks with accesses limited to the currently selected bank unless a Bank Change sequence has been executed. Upon reaching the end of a memory bank, the program counter will wrap around and point to the beginning of the current bank.

Each bank is further subdivided into pages of 256 bytes each, with 8 pages in every bank. The conditional JUMP instructions are restricted to operate within the memory page that they reside in.

Because of the sequence which the CALL instruction executes when pushing and loading the PC, it is possible to easily call and return from subroutines located in different memory banks (see *Figure 4*).

Upon executing an RET or RETR instruction for a call from one memory bank into another, a SEL MBx instruction should be excuted to restore the memory bank select flipflops to their original bank. However, no SEL MBx is needed after an interrupt since the flip-flops were never modified.



2.1.4 Program Status Word Bit Assignments

| Bit<br>Position | Contents                                     |
|-----------------|----------------------------------------------|
| 0               | Stack Pointer Bit, S0                        |
| 1               | Stack Pointer Bit, S1                        |
| 2               | Stack Pointer Bit, S2                        |
| 3*              | Memory Bank Select Bit 0                     |
| 4*              | Memory Bank Select Bit 1                     |
| 5*              | Register Bank Select Bit (0 = Bank 0,        |
|                 | 1 = Bank 1)                                  |
| 6*              | Auxiliary Carry. A carry from Bit 3 to Bit 4 |
|                 | generated by an add operation. Used only by  |
|                 | the decimal adjust (DA A) instruction.       |
| 7*              | Carry. A bit indicating the preceding        |
|                 | operation resulted in an overflow or an      |
|                 | underflow from the 8-bit accumulator.        |

\*Note 1: Bits 3 through 7 are saved on the stack by subroutine calls or interrupts. Bits 3 and 4 are restored upon execution of an RET instruction, whereas all 5 bits are restored by RETR.

Note 2: F0 is not saved on the stack (as in an 8048).

Note 3: Bits 0-5 cleared on a RESET.

#### 2.1.5 Stack Pointer (SP)

The stack pointer is an independent 3-bit counter which points to designated locations in the internal RAM that holds subroutine return parameters. The stack itself is located in RAM locations 8-23 (see *Figure 5*).

Each entry in the stack takes up two bytes and contains both the PC and status bits. When reset to zero, the stack pointer actually points to locations 8 and 9 in RAM. Since the stack pointer is a simple up/down counter, an overflow will cause the deepest stack entry to be lost (the counter overflows from 111 to 000 and underflows from 000 to 111). Note: If the level of subroutine nesting is less than eight (8), the unneeded

stack locations may be used as RAM.

|     |                 |     |   |            |   |   | LOCATION | POINTER       |
|-----|-----------------|-----|---|------------|---|---|----------|---------------|
| F   | PSW3-7<br>PC4-7 |     |   | 3-7 PC8-12 |   |   | 9        | 000           |
|     |                 |     |   | PC0-3      |   |   | 1.       | 000           |
| 9 8 | 7 6 1           | 5 4 | 3 | 2          | 1 | 0 | Γ        | TL/DD/5526-12 |

Note: The odd numbered RAM bytes in the stack area have two (2) extra bits to allow for storage of the bank select switch bits. This feature allows interrupt routines and subroutines to be located outside the current 2k program memory bank.

FIGURE 5. Typical Stack Composition

# 2.0 Functional Description (Continued)

## 2.1.6 Data Memory (On-Chip RAM)

The data memory nominally consists of 64 8-bit locations and is utilized for working registers, the subroutine stack, pointer registers and scratch pad. There are two sets of working/pointer registers (R0–R7) which are selected by the Select RAM Bank instruction. The stack area is located in locations 8–23. Locations 32–63 contain the scratch pad memory. To facilitate 16-bit Video Memory Management there are two 8-bit extension registers (RA and RB) which are associated with the R0 and R1 registers respectively of whichever RAM bank is currently selected (see *Figure 6*). i.e., There is only one RA register and only one RB register.



TL/DD/5526-13

#### FIGURE 6. RAM Memory Map

#### 2.1.7 Timer

The On-Board Timer is an 8-bit up counter which sets the Timer Overflow Flag and generates an internal interrupt (if enabled) whenever it overflows from FF to zero. The Timer may be stopped, started, loaded and read from by the CPU. The Timer clock is derived from the CPU clock as shown in *Figure 7*. Whenever a Start Timer instruction is executed the  $\div$  32 is initialized to its zero state to insure a full count measurement. After overflow the timer keeps counting until the next FF to zero overflow at which time the overflow flag will be set and another interrupt generated. The overflow flag can only be reset through the JTF and JNTF instructions.



# 2.1.8 Interrupts

The interrupt circuitry handles two generic classes of interrupt conditions called Internal and External. Either class has its own master control which can be activated through software enable and disable instructions. On an interrupt service the currently executing instruction is completed, then two CPU cycles are used as the program counter and bits 3–7 of the PSW are pushed onto the stack and stack pointer is incremented. Then the interrupt vector address (3 or 7) is loaded into the PC and service started. Whenever an interrupt condition is being serviced all other interrupts of either class are locked out until a RETR instruction is executed to conclude interrupt service. If both an external and internal interrupt arrive at the same time, the external interrupt is recognized first.

#### 2.1.8.1 External Interrupt

The External Interrupt consists solely of the shared INTR/ RE10 pin. External interrupts on this pin will be detected if the setup and hold times as shown in the timing diagrams are met. This pin is a level sampled interrupt which means that as long as the pin is low during the sampling window an interrupt will be generated. In addition, the INTR pin is the only external pin whose logic state can be directly tested through software.

#### 2.1.8.2 Internal Interrupts

The Internal Interrupts consist of seven internal operational conditions plus the light pen arranged in an 8-bit wide register as shown in *Figure 8*. Activation of an internal interrupt condition causes a corresponding register bit to be set, *Figure 9*. Each internal interrupt may be individually masked out through the Interrupt Mask register which has the same bit assignments as the Interrupt register and can be loaded from the accumulator. A zero in the Interrupt Mask register inhibits the interrupt and a one enables it. Further interrupt processing is as shown. To determine which of the eight internal conditions caused the interrupt the CPU must read the Interrupt register into the accumulator. To acknowledge receipt of the interrupt certain bits are automatically cleared on a read while others are reset upon service of the particular interrupt.

The conditions under which each of the interrupts are generated and cleared are as follows:



Note: The interrupt flags indicated by an asterisk (\*) are cleared when the Interrupt Register is read.

#### FIGURE 8. Internal Interrupt Register

#### Bit

0 Vertical Interrupt—Generates an interrupt at the end of the display row designated by the Vertical Interrupt Register. Interrupt bit cleared on a CPU read of the interrupt register. If VIR > Vertical Length Register no interrupt will be generated.



FIGURE 9. Internal Interrupt Processing

## Bit

- 1 End of Row Interrupt—Generates an interrupt at the end of each display row when the Current Row Start Register is updated for the next row. Used in conjunction with the Row Sequencing Control Bit (5) in the System Control Register to implement Row Pointer Look-Up Tables and Horizontally Split Screens. Interrupt bit cleared on a CPU write to the Home Register. Does not generate interrupts for those rows blanked during vertical blanking.
- 2 UART Transmit Buffer Empty—Generates an interrupt when the Transmit Buffer empties out after dumping a character into the Transmit Shift Register. Interrupt bit cleared on a CPU write to the Transmit Buffer.
- 3 Transmitter Empty—Generates an interrupt when BOTH the Transmit Buffer and Transmit Shift Register are empty. The interrupt bit is cleared when the CPU loads the transmit buffer.
- 4 UART Receiver Buffer Full—Generates an interrupt when the Receiver Buffer fills up with a character from the Receive Shift Register. Interrupt bit cleared on a CPU read of the Receiver Buffer.
- 5 Light Pen Interrupt—Generates an interrupt on each falling edge detected on the shared LP/RE9 pin. Since only falling edges generate interrupts and the input is sampled each CPU Cycle, a high level must be sampled between falling edges in order to be considered a new interrupt. This interrupt is used to latch the light pen position registers. For further information see Light Pen Description. Interrupt bit cleared on a CPU read of the interrupt register.

#### Bit

- 6 Timer Interrupt—Generates an interrupt when the internal 8-bit Timer overflows from FF to 00. Interrupt bit cleared on a CPU read of the interrupt register.
- 7 Real-Time Interrupt—Generates interrupts at a software programmable frequency that is generally in the Hertz range. (See CPU Clock Generation.) Thus permitting the implementation of a real-time clock or timer. Interrupt bit cleared on a CPU read of the interrupt register.

#### 2.1.9 Clock Generation

All chip clocks are derived from the one external crystal connected between pins 22 and 23. This master clock also doubles as the video dot clock. The crystal frequency is constrained to lie within the range of 3 to 18 MHz. The CPU clock is derived from the crystal clock by either using it directly or by dividing down by a factor of 1.5 (*Figure 10*).



TL/DD/5526-17

#### FIGURE 10. CPU Clock Generation

The choice is software programmable through bit 0 in the System Control Register. The exact selection is made in consideration of the fact that the CPU clock must lie within the range of 3 to 12 MHz. In addition, the choice of divide by modes will also impact the display character cell width due to the nature of the video controller. Specifically with  $\div$  1.5

7

the cell width must be  $\geq$  8 dots wide whereas with  $\div$  1 the cell width must be  $\geq$  6 dots wide.

The low clock rates necessary to implement Cursor Blinking, Character Blinking and the Real-Time Interrupt are derived by passing the vertical sync frequency through a 5-bit Blink Rate Divisor Register, *(Figure 11)*. The resultant frequency is used as the Cursor Blink Clock. This clock is then further divided by 2 to yield the Character Blink and Real-Time Interrupt Clocks. For example, to get a 1 Hz real time interrupt, with a 60 Hz system, set the 5 bit Divisor Register to 30 in order to yield a 2 Hz signal which is then divided by 2.



FIGURE 11. Blink Clock Generation

## 2.1.10 Oscillator Operation

The on-board oscillator circuit consists of a phase inverter which, when used with an external parallel resonant tank, (*Figure 12a*), will yield the required oscillator clock. Crystals should be specified for AT cut and parallel resonant operation with the desired load capacitance (typically 20 pF). If one desires to externally generate the clock and input it to the chip, he may do so by driving XTAL1 (pin 23) and XTAL2 (pin 22) as shown in *Figure 12b*.



TL/DD/5526-20

Note: Use AS TTL devices if faster than 12 MHz. FIGURE 12b. External Oscillator Mode

#### 2.2 DISPLAY MEMORY CONTROLLER

The video display data resides in the external Video Memory which is managed by the Display Memory Controller (DMC) through the System Bus. Either the CPU or the Video Controller may access the display memory by presenting its requests to the DMC. A maximum of three Video Memory accesses (Reads or Writes) can be performed by the DMC during each CPU instruction execution cycle. Because the CPU can access the Video Memory, one may expand CPU I/O or data memory by memory mapping into the Video Memory space. Up to 64k locations may be addressed over the 16-bit System Bus. Data word widths may be 8 or 16 bits depending upon whether external character attribute selection is used. The actual bus multiplexing mode is controlled by bit 4 in the System Control register. The Video Controller has the highest priority in obtaining Video Memory accesses with the CPU getting in on a space available basis. If all memory accesses are being taken by the Video Controller (rarely), the CPU is put into a wait state should it try to access video memory. To ease accessing requirements and boost throughput the Video Controller utilizes a 4-level data FIFO which is normally kept full of display data.

#### 2.2.1 Display Memory Control Registers

In order to facilitate the management of video data for such features as a Screen scroll, memory paging and row lookup the DMC utilizes a number of registers which address the video RAM space. Each of these pointers is 16 bits wide and writable or readable from the 16-bit HACC/ACC pair as the case may be. There are 2 video data accessing modes as determined by bit 5 in the SCR, Sequential and Table Lookup. The functions of the pointer registers vary depending upon the accessing mode selected. Their designators are:

- HOME = Home address register. Read and write.
- BEGD = Beginning of diplay RAM. Write only.
- ENDD = End of display RAM. Write only.
- CURS = Cursor address register. Read, Write, Increment, Decrement.
- SROW = Status section register. Write only.
- CRSR = Current row start register. Not directly accessed.

#### 2.2.2 Sequential Access Mode

In this mode display data is accessed from sequential address locations in the video memory until the data requirements for the current screen field are fulfilled. The location from which the first display character is taken is the one pointed to by the HOME register. By modifying the contents of HOME one may implement a row scroll or paging operation. The BEGD and ENDD are used to control the wraparound condition when HOME gets near the end of available display RAM as determined by ENDD. In this instance, when sequential accessing brings us to the end of memory as pointed to by ENDD, the controller wraps around by jumping back to the beginning of display memory as pointed to by BEGD. The value in ENDD should be the last location in display memory + 1. Also the size of the display memory between BEGD and ENDD (ENDD - BEGD) must be an integral number of display rows. The CURS in both accessing modes merely identifies the current cursor position in display memory so that the cursor characteristics can be inserted into the video at the appropriate character position.

In addition to the display of normal video data one may elect to have a special status section displayed using data from a separate section of video memory. The status section would consist of an integral number of display rows on the bottom of the screen. This feature operates by reloading the video RAM pointer with the contents of SROW when the desired row position at which to start the status section comes up. The particular row at which the status display starts is defined in the Timing Chain. Once the video RAM pointer is jumped to SROW, data accessing again proceeds sequentially from there until the data requirements for the current field are satisfied.



7-17

7



7-18

| 2.5.1 TM      | P Timing Chain Registers (Continued)                                                                                                                                                                                                                                              |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TCP           | Horizontal Timing                                                                                                                                                                                                                                                                 |
| 3             | Horizontal Sync End Register — HSER 7 bits                                                                                                                                                                                                                                        |
|               | — Character position in horizontal scan after which horizontal sync ends (falling edge), HSER $\leq$ HLR.                                                                                                                                                                         |
|               | Enter desired count + 2.                                                                                                                                                                                                                                                          |
| Note: The     | polarity of the horizontal sync signal can be inverted by switching the values in the two horizontal sync registers.                                                                                                                                                              |
| TCP           | Character Height Definition                                                                                                                                                                                                                                                       |
| 4             | Character Scan Height Register — CSHR 4 bits (see Figure 16a)                                                                                                                                                                                                                     |
| High          | Scan line height of a character cell.                                                                                                                                                                                                                                             |
| Nibble        | - Enter desired number of scan lines - 1.                                                                                                                                                                                                                                         |
| 4<br>Low      | Extra Scans/Frame — ES/F 4 bits<br>— Number of extra scans to be added to a frame if desired.                                                                                                                                                                                     |
| Nibble        | - Enter desired number of extra scans - 1.                                                                                                                                                                                                                                        |
|               | — To get no extra scans make ES/F = CSHR. ES/F must be $\leq$ CSHR.                                                                                                                                                                                                               |
| ТСР           | Vertical Timing                                                                                                                                                                                                                                                                   |
| 5             | Vertical Length Register — VLR 5 bits                                                                                                                                                                                                                                             |
| Ū             | <ul> <li>Total number of display and retrace rows in a frame.</li> </ul>                                                                                                                                                                                                          |
|               | - Enter desired number of rows $-1$ .                                                                                                                                                                                                                                             |
| 6             | Vertical Blank Register — VBR 5 bits (Rows/Screen)                                                                                                                                                                                                                                |
| 0             | <ul> <li>Row position in vertical scan after which vertical blanking begins, VBR &lt; VLR.</li> </ul>                                                                                                                                                                             |
|               | <ul> <li>— How position in vertical scale area which vertical blanking begins, vbH &lt; vEH.</li> <li>— Enter desired number of displayed rows - 1.</li> </ul>                                                                                                                    |
| 7             | Vertical Sync Begin Register — VSBR 4 bits                                                                                                                                                                                                                                        |
| ,<br>High     |                                                                                                                                                                                                                                                                                   |
| Nibble        | <ul> <li>Scan line position in first blank row at which vertical sync begins (falling edge). Sync starts 1 char time after<br/>blanking for that line starts (except when VSBR = CSHR sync will start 1 char time after blanking of the last<br/>displayed scan line).</li> </ul> |
|               | <ul> <li>Enter desired scan line position - 1.</li> </ul>                                                                                                                                                                                                                         |
| 7             | Vertical Sync End Register — VSER 4 bits                                                                                                                                                                                                                                          |
| Low<br>Nibble | <ul> <li>Scan line position after start of vertical sync at which vertical sync ends (rising edge). Sync ends 1 char time after horizontal blanking for that scan line start.</li> </ul>                                                                                          |
|               | <ul> <li>Enter desired scan line position - 1.</li> </ul>                                                                                                                                                                                                                         |
| Note: If VS   | ER = VSBR there will be no vertical sync signal.                                                                                                                                                                                                                                  |
| 8             | Status Row Begin Register — SRBR 5 bits                                                                                                                                                                                                                                           |
|               | <ul> <li>Row count after which the status row is inserted.</li> </ul>                                                                                                                                                                                                             |
|               | <ul> <li>Enter desired row position - 1.</li> </ul>                                                                                                                                                                                                                               |
| TCP           | Cursor and Graphics Control                                                                                                                                                                                                                                                       |
| 9             | Blink Rate 5 bits                                                                                                                                                                                                                                                                 |
| Upper         | <ul> <li>Divider driven by the vertical sync frequency to yield the slow cursor, character and real-time blink rates.</li> </ul>                                                                                                                                                  |
| 5 Bits<br>9   | - Enter desired divisor - 1.                                                                                                                                                                                                                                                      |
| Lower         | Blink Duty Cycle 3 bits<br>— Approximate ON time of blink signal.                                                                                                                                                                                                                 |
| 3 Bits        | - 000 = shortest, 111 = longest (100 = 50% duty cycle).                                                                                                                                                                                                                           |
| 10            | Graphics Column Register — GCR 8 bits                                                                                                                                                                                                                                             |
|               | <ul> <li>Assign dot positions to left, middle and right character cell columns for block graphics operation.</li> </ul>                                                                                                                                                           |
| 11            | Graphics Row Register — GRR 8 bits                                                                                                                                                                                                                                                |
|               | <ul> <li>Defines scan count at which middle row for block graphics characters begins (upper nibble) and at which<br/>bottom row begins (lower nibble). The middle row (upper nibble) must be ≥ 1.</li> </ul>                                                                      |
|               | — Enter desired scan count – 1.                                                                                                                                                                                                                                                   |
| 12            | Underline Size Register — USR 8 bits (see Figures 16a, b, c)                                                                                                                                                                                                                      |
|               | <ul> <li>Defines the beginning (upper nibble) and ending (lower nibble) scan lines for the underline attribute. Values must be &lt; CSHR.</li> </ul>                                                                                                                              |
| 13            | Cursor Size Register CSR 8 bits (see Figures 16a, b, c)                                                                                                                                                                                                                           |
|               | <ul> <li>Defines the beginning (upper nibble) and ending (lower nibble) scan lines for the cursor. Values must be ≤<br/>CSHR.</li> </ul>                                                                                                                                          |
|               |                                                                                                                                                                                                                                                                                   |





Note: The internal cursor flip-flop gets set to ON whenever a scan line corresponding to the begin cursor nibble is reached, and gets set to cursor OFF whenever a scan line corresponding to the end cursor nibble is reached. The cursor attributes are inserted whenever the character position being displayed corresponds to the one pointed to by the cursor address register. A similar situation applies for characters with the underline attribute selected. Therefore, care should be taken when setting the ES/F register and setting the cursor and underline sizes. In particular the ES/F value should not be between the upper nibble and lower nibble values of the underline size register or between the upper nibble and lower nibble values of the cursor size register. To use the cursor size negister to a value greater than CSHR.

#### 2.5.2 TIMING CHAIN LOAD VALUE EXAMPLE

It is desired to have a display field of 80 columns by 25 rows with the last screen row being a status row. It has been determined that 25 character width times will be necessary to complete horizontal retrace and that Horizontal sync should be positioned to start a full seven character times after blanking and end twenty characters after blanking to give us a total sync width of 13 character times. (See *Figure 17* for example.)

Additionally, vertical retrace will take 23 scan line times to complete with vertical sync starting three scan line times after vertical blanking begins and occupying a total period of 11 scan lines.

It is desired to make the character cells 12 scan lines tall. The cursor will be a block shape and occupy the bottom 11 scan lines in a cell. The underline attribute will actually be a strike through dash occupying the 4th scan line from the top in a cell.

Our line width is 80 displayed characters plus 25 for retrace making HLR = 80 + 25 - 1 = 104. Blanking will start after the 80th character so HBR = 80 - 1 = 79. To achieve seven character times after horizontal blanking, HSBR = 87 + 2 = 89. To achieve twenty character times after blanking HSER = 100 + 2 = 102 (note 102 - 89 = 13 total). Cell height is 12 lines so CSHR = 12 - 1 = 11. Since there are 12 scan lines per cell or row, vertical retrace will require 23/12 = 1 row and 11 scan lines. This makes our total row count VLR = 25 + 1 - 1 = 25 and ES/F = 11 - 1 = 10. Thus, timing chain location 4 would be coded: 1011 1010. We will display 25 rows so VBR = 25 - 1 = 24. Vertical sync will start at the beginning of the fourth scan



line of the row after blanking begins so VSBR = 4 - 1 = 3. It will run for 11 scan lines or specifically the 4, 5, 6, 7, 8, 9, 10, 11, 12, 1, 2 ending at the beginning of the 3rd so VSER = 3 - 1 = 2. The status row will be after the 24th so SRBR = 24 - 1 = 23. To specify the underline and cursor sizes one must remember that the first scan line is numbered 0. To get our 11 line block cursor we begin after the 0 line and end at the end of the 11 line making CSR = 0000 1011. The underline dash will be USR = 0011 0100. Note that the CSHR determines the scan counter modulo and if a scan compare register value (ES/F, VSBR, VSER, USR, CSR) is never reached, the signal end or begin will never be initiated.

# 2.6 ATTRIBUTES

Eight independent attributes may be inserted it to the video dot stream to affect display characters on either an individual or global basis. The eight attributes along with their con-



FIGURE 18. Attribute Bit Assignments

trol word bit assignments are detailed in *Figure 18*. The scope with which a particular set of attributes affects the display depends upon whether attribute control is internal or external as determined by bit 4 in the VCR.

Attributes are present if the corresponding bit is a ZERO (low).

# 2.6.1 Internal Attribute Selection

In internal mode attribute control comes from one of two internal attribute latches designated AL0 and AL1, either of which is directly loadable from the CPU accumulator. The choice of which of the two is used for a particular display character is determined by bit 7 (MSB) in the display memory data byte with 0 = AL0 and 1 = AL1. (Characters are represented in display memory as ASCII values occupying the low 7 bits of each 8-bit byte thus leaving bit 7 free for attribute control.)

## 2.6.2 External Attribute Selection

In external mode each display character has associated with it, a dedicated attribute field in the form of a high 8-bit extension to the regular display memory character byte. To use this mode the system bus msut be configured for 16-bit bidirectional operation (SCR bit 4 = 1) and external attributes must be selected (VCR bit 4 = 1).

#### 2.6.3 Attribute Processing

Each of the eight attributes may be independently enabled thus yielding a number of possible combinations. The exact processing involved is shown in *Figure 19*. Note that attributes are always present. Whether any of them are active depends upon the particular control bit being enabled in the latch or memory.



7

# 2.6.4 Attribute Operation

Reverse Video: A character and its surrounding cell are reversed in video from what was selected for the rest of the screen.

Half Intensity: To use the half intensity function the shared INTENSITY/FO CLK pin (25) must be selected for INTENSITY operation by setting SCR bit 6 low. In operation the half intensity pin will be low whenever a character for which the attribute is active is being displayed. To perform the actual attenuation function external circuitry must be connected between the INTEN and Video Output pins. In fact the signal may be used for another purpose such as switching between two colors.

Blink: A character or the field around it blinks as selected by VCR bit 0.

- Double Height: A designated character is stretched out so that it will occupy a 2-row tall space. This attribute is implemented by slowing down by half the scan line stepping to the internal character generator. To use this attribute the desired double high character must be placed into the two display memory locations corresponding to the top and bottom row positions. For both locations the double high attribute is set. In addition the Blank attribute for the bottom character is also set to tell the controller it is the bottom half of a double high character. The double high attribute has no effect on element graphics or on pixel graphics displays. If an external character generator is used special circuitry must be employed to implement double high characters.
- Double Width: A designated character is stretched out so that it will occupy a 2-character cell wide space. This attribute is implemented by slowing down by half the clock to the video dot shifter. To use this attribute the desired double wide character must be placed in the left character position and the double wide attribute bit set. The following character position (right) can have any character as it will be ignored.
- Underline: If set this attribute causes the underline figure to be added to the video dot stream. Since the underline, like the cursor, can be specified as to position and size in the character cell, the underline can be an overline, block, strike through or any one of a number of effects. The underline overwrites any dot where it overlaps the character.
- Blank/Double A character is inhibited from being displayed while still allowing it to be stored in the display memory. If this attribute and the double height attribute are set for the same character, the normal blank function is disabled for that character position and the character is displayed as the bottom half of a double height character.
- Graphics: This attribute determines whether the video memory data byte as accessed by the display memory controller is routed through the character generator or block graphics control logic. If routed through the block graphics logic (attribute active) the effect on the video display will be as described in the Block Graphics section. Note that because Block Graphics mode is selected as an attribute it may be mixed in with normal alphanumerics characters. Also all other attributes with the exception of double height operate on the block graphics characters.

# 2.7 CHARACTER GENERATOR

The internal character generator holds 128 characters in a 7 x 11 matrix. The standard character sets are addressed using 7-bit ASCII codes stored in the display memory. When operating with fonts smaller than the maximum of 7 x 11, zeroes are encoded into the unused bits. When putting out a character the video controller always starts character generation on the second scan line of a row, leaving the first scan line blank. Similarly, the first (left) column in a character cell is blanked with character generation starting on the second column. Therefore, the specified cell size must be one greater in height and width than the display characters (including descenders) otherwise they will be chopped off. If the character cells are larger than the internal 7 x 11 matrix, blank dots will be put out after exhausting the internal generator (See *Figure 20* for example.)



# 2.7.1 External Character Generation

The chip may be used with an external character generator by switching over to a pixel graphic display mode with modified address stepping as controlled by VCR bits 6, 7. In this mode an external character generator supplies pixel data to the chip as depicted in Figure 21. Character addressing comes from the display memory and scan line stepping from a 4-bit counter clocked by the Horizontal Sync. Scan line synchronization is achieved by using the Scan Count Clear signal coming out on RE11, pin 36. After the display of a row it pulses low to initialize the scan line counter for the start of a new row. In pixel mode both the character and any spacing between characters must be encoded into the external character generator. In addition, the chip will access and use at most 8 bits of pixel data for each character cell. However, if the cell width is specified to be 9 or 10, the ninth and tenth dots will repeat what was coded into the first. Therefore, assuming at least one dot spacing between characters, external fonts can at most be seven dots wide.

No limitations apply to the height of a character as long as the external generator can supply all of the scan lines as specified by the CSHR. As in regular pixel mode the LSB brought in is the first dot put out.

Since the eighth data bit is used for character generation it cannot effectively be used for internal attribute latch selection although one of the latches will be selected every data byte. Therefore, both internal attribute latches must be loaded with the same values. If external attribute operation is specified the full 8-bit high order attribute field is available for usage.

#### 2.0 Functional Description (Continued) RAM ALE H SYNC ADDRESS SBO-SB15 LATCH V SYNC vo DATA NS405 ALE WRITE BUFFEF CHARACTER DISPLAY LATCH RE11 GENERATOR RAM RAM RAM BITS 4 BITS RD WR CLR EXT SCAN CNT 4-BIT CLR CLK COUNTER

FIGURE 21. External Character Set Implementation

# 2.8 BLOCK GRAPHICS

Block graphics is an alternative display mode to normal alphanumerics which is selected through attribute bit 7. Example (*Figure 22*). It can operate on a character cell by character cell basis (see Attributes) and words by rerouting display memory bytes through the Block graphics logic instead of the internal character generator.



TL/DD/5526-31

7-23

FIGURE 22. Example Block Graphics Display Patterns

The Graphics Logic operates by partitioning the character cell space into nine possible areas as shown in *Figure 23* and then using the seven lower bits in the display data byte to turn these areas on or off. In this way one can draw contiguous lines or simple geometric figures while at the same time displaying alphanumeric characters in other cells.

The partitioning of the cell is controlled by two timing chain registers which specify two Horizontal and two Vertical cut off points to the graphics logic. Through these two registers one can make the sections as large or as small as desired, even eliminating sections entirely. Note that data bits 0 and 5 each control two sections as depicted in *Figure 23*.

# 2.8.1 Graphics Partitioning



#### TL/DD/5526-32

TL/DD/5526-30

# FIGURE 23. Block Graphics Cell Partitioning

The registers defining the graphics areas function as follows:

The Graphics Row Register — 8 bits (GRR) is divided into the following two (2) registers:

- Graphics Middle Row, (GMR): Defines the scan count at which the middle row begins (4 most significant bits of GRR).
- Graphics Bottom Row, (GBR): Defines the scan count at which the bottom row begins (4 least significant bits of GRR).

See Figure 24.1a for row example.

The Graphics Column Register — 8 bits (GCR) controls vertical partitioning through bit patterns as follows: (See *Figure* 24.)



TL/DD/5526-33





For all bits in the Graphics Column Register, a one assigns that bit position to the middle column. A zero in an L bit position assigns that bit position to the left column. A zero in an R bit position assigns that bit position to the right column. There is always at least one middle dot although the left and right sections may be eliminated entirely. For 10 dot wide cells the 10th bit will repeat the 9th bit. An easy way to determine the column partitioning is to fill the GCR with all ones, thereby making it one large middle section. Then, starting from the outermost L and R bit positions, put zeros in until the left and right sections are the sizes needed.

#### 2.9 PIXEL GRAPHICS

When bits 6 and 7 of the Video Control Register are both set to 1, the character generator and block graphics circuits are disabled. Video output directly reflects the contents of the display memory byte on a pixel (dot) per bit basis with data output LSB first. Example (*Figure 25*).

Nine bits at a time are accessed from each video memory location with as many bits being used as defined in the character cell width specification. If a cell width of 10 is specified



FIGURE 25. Example Pixel Graphics

TL/DD/5526-34

the 10th bit will merely repeat the 9th bit. Attributes are still operable in pixel mode, on a data byte basis, with internal and external operation possible. With internal attribute latch operation the same values must be loaded into both latches since the usual latch select bit is now being used for pixel control. Unless, however, only a 7 dot wide cell is used leaving the 8th bit free. With external attribute operation we are now limited to a 7-bit attribute field since pixel data can now occupy 9 of the 16 bus bits. Because of this the LSB attribute, Reverse Video is totally disabled from operation in Pixel Graphic mode. This also applies to internal attribute latch operation. Note, however, that reverse entire screen video is still operable. Address sequencing through the video memory is sequential with as many data bytes being read in as is necessary to satisfy the pixel requirements of the screen.

#### 2.10 LIGHT PEN

Activation of the light pen interrupt causes the horizontal and vertical screen position of the currently displayed character to be latched into the Horizontal Light Pen Register HPEN (7 bits) and Vertical Light Pen Register VPEN (5 bits) respectively. Both HPEN and VPEN may be read into the CPU accumulator. The values latched remain in VPEN and HPEN until another light pen interrupt latches new values.

#### 2.11 UART

The UART features full duplex operation with double buffered Receive and Transmit sections. Baud rate generation is fully programmable through a 2-stage divider chain. CPU control of the UART is extensive with polled or interrupt driven operation possible.



FIGURE 26. TMP UART Block Diagram

TL/DD/5526-35

# 2.11.1 UART Control

**UART Status Register (STAT):** Contains error and status bits which reflect the internal state of the UART. Read into CPU accumulator. Bits 0, 5 are the same as those found in the internal interrupt register.



TL/DD/5526-36

UART Status Register bits 1, 2, 3 are only cleared on a chip reset or a read of the UART Receive Buffer. If another word were to come in before the Receive Buffer could be read the errors associated with the new word would add to those already present. The receipt of a new word can cause the three bits to go from a 0 to a 1, but not from a 1 to a 0.

#### FIGURE 27. UART Status Register

Note: The Transmit Output Register Empty flag is set to one whenever the transmitter is idle. The flag is reset to zero when a data character is transferred from the Transmit Buffer to the Output Register. This transfer does not occur until the next rising edge of the internal UART Transmit Clock. The Transmitter Output Register Empty flag occurs at the beginning of the last stop bit.

**UART Control Register (UCR):** Contains control bits which configure the format of transmitted data and tests made upon received data. Written to from CPU accumulator.



#### 2.11.2 Baud Clock Generation

The basic BAUD clock is derived from the crystal frequency through a two-stage divider chain consisting of a 3.5–11 prescale and an 11-bit binary counter. (*Figure 29*). The divide factors are specified through 2 write only registers shown in *Figure 30*. Note that the 11-bit Baud Rate Divisior spills over into the Prescale Select Register. The correspondences between the 4-bit Prescale Select and Prescale factors is shown in Table I. There are many ways to calculate the two divisor factors but one particularly effective method would be to try to achieve a 1.8432 MHz frequency coming out of the first stage then use the BAUD Rate Divisor factors shown in Table II.

| PRESCALE REGISTER  |                   |
|--------------------|-------------------|
| 3 2 1 0 X 10 9     | 8 7 6 5 4 3 2 1 0 |
| PRESCALE SELECT    | BAUD RATE DIVISOR |
| FIGURE 30. UART BA | TL/DD/5526-39     |

#### **TABLE I. Prescale Factors**

| Prescale<br>Select | Prescale<br>Factor |  |  |  |  |  |  |
|--------------------|--------------------|--|--|--|--|--|--|
| 0000               | 3.5                |  |  |  |  |  |  |
| 0001               | 4                  |  |  |  |  |  |  |
| 0010               | 4.5                |  |  |  |  |  |  |
| 0011               | 5                  |  |  |  |  |  |  |
| 0100               | 5.5                |  |  |  |  |  |  |
| 0101               | 6                  |  |  |  |  |  |  |
| 0110               | 6.5                |  |  |  |  |  |  |
| 0111               | 7                  |  |  |  |  |  |  |
| 1000               | 7.5                |  |  |  |  |  |  |
| 1001               | 8                  |  |  |  |  |  |  |
| 1010               | 8.5                |  |  |  |  |  |  |
| 1011               | 9                  |  |  |  |  |  |  |
| 1100               | 9.5                |  |  |  |  |  |  |
| 1101               | 10                 |  |  |  |  |  |  |
| 1110               | 10.5               |  |  |  |  |  |  |
| 1111               | 11                 |  |  |  |  |  |  |

#### TABLE II. Baud Rate Divisors (1.8432 MHz Input)

| Baud<br>Rate   | Baud Rate<br>Divisor (N - 1) |
|----------------|------------------------------|
| 110 (110.03)   | 1046                         |
| 134.5 (134.58) | 855                          |
| 150            | 767                          |
| 300            | 383                          |
| 600            | 191                          |
| 1200           | 95                           |
| 1800           | 63                           |
| 2400           | 47                           |
| 3600           | 31                           |
| 4800           | 23                           |
| 7200           | 15                           |
| 9600           | 11                           |
| 19200          | 5                            |

PRESCALER

**4 BITS** 

÷3.5 TO ÷11

CRYSTAL

TL/DD/5526-38

The frequency coming out of the BAUD Rate Divisor is then passed through the UART Multiplex Register. Through the UART Multiplex Register one can specify that the Transmitter or Receiver clock be the same or a power of two multiple of the other.

**UART Multiplex Register (UMX):** Contains the bits which determine the divisor which is used to count down from the primary baud rate when different rates are used for send and receive (eight bits).





The actual baud rate may be found from:

BR = Fc/(16\*N\*P\*D)

Where:

BR is the Baud Rate

Fc is the external crystal frequency

- N is one plus the value of the Baud Rate Divisor contained in the Baud Rate Select Register and the Prescale Select Register.
- P is the Prescale Divide Factor Selected by the value in the Prescale Select Register.
- D is the Multiplex Register Divide Factor

# **3.0 Slave Processing**

The TMP may be used as a slave video controller by having a host system perform Direct Memory Accesses into the display RAM. To assist in implementing such a system the chip features two DMA control pins-HOLD (Hold Request) and HLDA (Hold Acknowledge). These two signals come out on shared ROM Expand Bus pins RE8 and RE12. To request a DMA access a host would activate HOLD (active high and await the acknowledging HLDA from the TMP before proceeding with the DMA. The TMP only allows DMA operations during the vertical blanking period and will activate HLDA in response to a HOLD shortly after vertical blanking starts. In DMA mode all 16 TMP System Bus drivers are tri-stated while the bus control signals RAM ALE, RAM RD, RAM WR go to their inactive (high) states. A HOLD request must arrive two CPU cycles before vertical blanking starts; otherwise it will miss that retrace cycle and will have to wait until the next one, one frame later. Once DMA mode is entered, it is maintained for the duration of vertical blanking regardless of the state of HOLD. Near the end of vertical blanking the DMA mode will terminate in preparation for the display of the next frame, but the HLDA will NOT turn off. Specifically, this will occur one scan time before the end of vertical blanking. It is up to the designer to be sure that the host is off the BUS before this happens or suffer bus contention with the video controller. He can do this by either predetermining the length of time the host has to remain on the bus, or by using the end of vertical sync (as shown in *Figure 32*) to signal the end of a safe DMA period. If during DMA the CPU attempts to do a display memory access it would be put into a wait state until DMA is concluded and normal memory accessing is resumed.



TL/DD/5526-45

Vertical sync should be programmed to end as late as possible, but must end at least one scan time before the end of vertical blanking.

## FIGURE 32

# 4.0 Reset

The TMP will reset if the  $\overrightarrow{\text{RESET}}$  (32) pin is held at a logic low (< 0.8V) for at least five CPU cycle times. This pre-supposes that the V<sub>CC</sub> is up, stable and within operational limits (+5V  $\pm$  10%) and that the oscillator is running. For a power on reset, time must be allowed for the power supplies to stabilize (typically 50 ms) and the oscillator to start up. If power supply noise or ripple causes V<sub>CC</sub> to exceed the +5V  $\pm$  10% limits neither reset nor operation is guaranteed.

Internally, the RESET pin has a depletion load pullup that typically acts as a 30  $\mu$ A current source from V<sub>CC</sub> in the voltage range of interest. A typical reset circuit with a 0.5 second reset pulse is shown in *Figure 33*.



TL/DD/5526-41

FIGURE 33. Typical Reset Circuit

# 4.0 Reset (Continued)

During RESET a number of internal registers are initialized as follows:

4.1 CPU

# **4.2 INTERRUPTS**

Internal and External Interrupts disabled Internal Interrupt Register set to 000011X0

## 4.3 UART

Receiver initialized to look for start bit Status Register set to 11110000 Transmitter initialized to wait for OUT XMTR instruction Control Register bit 5 =0 (No BREAK)

# 4.4 VIDEO

Video generation shutdown (VCR bit 5 = 0) FIFO Cleared Out Timing Chain Character Counter = 0 Timing Chain Scan Counter = 0 Timing Chain Row Counter = 0 Timing Chain Blink Counter = 0

#### **4.5 PIN STATES AT RESET**

| Pins 1-8 (SB0-7)         | In TRI-STATE during reset and until either the CPU executes a MOVX instruction or bit 5 of<br>the VCR is set.                                                                                                                     |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pins 9–16 (SB8–15)       | If bit 4 of the SCR is set, SB8–15 will behave like SB0–7. If bit 4 of the SCR is cleared, SB8–<br>15 will act as outputs (any of which may be either high or low). Note that bit 4 of the SCR may<br>be one or zero at power-up. |
| Pin 17 (VID CLK/FI CLK)  | High during reset and until bit 5 of the VCR is set.                                                                                                                                                                              |
| Pin 18 (RAM ALE)         | High during reset and until the CPU executes a MOVX instruction or bit 5 of the VCR is set.                                                                                                                                       |
| Pin 19 (RAM WR)          | High during reset and until the CPU executes a MOVX (of the output to display RAM variety) instruction.                                                                                                                           |
| Pin 20 (RAM RD)          | High during reset and until either the CPU executes a MOVX instruction or bit 5 of the VCR is set.                                                                                                                                |
| Pin 21 (ALE)             | Pulses continuously.                                                                                                                                                                                                              |
| Pin 22 (XTAL 2)          | Crystal input or master clock input.                                                                                                                                                                                              |
| Pin 23 (XTAL 1)          | Crystal input.                                                                                                                                                                                                                    |
| Pin 24 (Gnd.)            |                                                                                                                                                                                                                                   |
| Pin 25 (INTENS/FO CLK)   | May be either high or low during reset.                                                                                                                                                                                           |
| Pin 26 (VO)              | Low (because of asserted blanking signals) from reset until bit 5 of the VCR is set.                                                                                                                                              |
| Pin 27 ( <del>VS</del> ) | In TRI-STATE mode upon RESET, enabled when bit 5 of the VCR is set.                                                                                                                                                               |
| Pin 28 (HS)              | Low from reset until bit 5 of the VCR is set.                                                                                                                                                                                     |
| Pin 29 (EA)              | Input only. (must be tied HIGH (VIH2))                                                                                                                                                                                            |
|                          |                                                                                                                                                                                                                                   |

| 4.0 Reset (Continued)                                        |                                                                                                                                                      |
|--------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin 30 (PSEN)                                                | Active during reset.                                                                                                                                 |
| Pin 31 (RD)                                                  | High during reset and until an IN PORT instruction is executed.                                                                                      |
| Pin 32 (RESET)                                               | Input only.                                                                                                                                          |
| Pin 33 (SO)                                                  | High during reset and until an OUT XMTR instruction is executed.                                                                                     |
| Pin 34 (SI)                                                  | Input only.                                                                                                                                          |
| Pin 35 (RE12/HLDA)                                           | If HOLD is low: low during reset. If HOLD is high: low at falling edge of ALE and during PSEN, may be low or high at rising edge of ALE.             |
| Pin 36 (RE11/SC CLR)                                         | If reset asserted: low at falling edge of ALE and during PSEN, sampled value of internal Scan<br>Count Clear signal is output at rising edge of ALE. |
| Pin 37 (RE10/INTR)<br>Pin 38 (RE9/LPEN)<br>Pin 39 (RE8/HLDR) | If reset asserted: low at falling edge of ALE and during PSEN. Always in TRI-STATE at rising edge of ALE.                                            |
| Pins 40-47 (RE0-7; I/O0-7)                                   | If reset asserted: low at falling edge of ALE, in TRI-STATE during PSEN, and may be either high or low at the rising edge of ALE.                    |

Pin 48 (V<sub>CC</sub>)

# 5.0 Extra Attributes

One may want to expand the external attribute field by adding more bits so that functions such as color (Red-Green-Blue drive) or grey scale may be implemented. Like the eight attributes which the chip handles internally these extra attributes would operate on a character cell basis. To add attribute bits one would have to duplicate the internal 4 level character/attribute FIFO externally using fast MSI chips. To assist in handling the external FIFO circuitry the TMP features two FIFO clocking signals on pins 17 and 25. The FIFO IN Clock (FI CLK) is used to strobe attribute data into the external FIFO circuits in synchronism with the internal TMP FIFO. Its timing is identical to RAM RD but is only active when the video does a display RAM read to load its FIFO. The FIFO OUT Clock (FO CLK) pulses for 1-3 bit times each time the video starts the display of a new character cell. The external FIFO would use the rising edge of this signal to clock out or latch the attribute output.

In order for the TMP CPU to access the additional attribute bits special bus gating arrangements would have to be worked out on the System Bus (Video Data Bus is at most 16 bits wide). Unless one were to run with internal attributes or only use a few of the external attributes in which case the unused bits could be used with the external FIFO. Whenever using the FO CLK the Intensity attribute is disabled since they both share the same pin.

# 6.0 TMP BUS Interfacing

The two external buses on the TMP, ROM Expand and System are easily interfaced to as shown in *Figures 34* and *35*. Important bus information output from the chip is latched using the rising or falling edges of the various control signals. I/O port information is read in through a TRI-STATE® buffer chip such as an 81LS96.





\*MOVL A,R1

STOP T

JTF addr

\*JNF0 addr

\*JNF1 addr

JXI addr \*EN II

\*MOVX @R1,A

\*INCL R1

MOV T.A

CPL F0

CPL F1

\*JNTF addr

JNXI addr

DIS XI

\*MOVX A,@R1

JF0 addr

JF1 addr

\*DECL R1

MOV A,T

STRT T

CLR F0

CLR F1

\*DIS II

EN XI

\*MOVL R1,A

MOV A.INTR

\*LONG R1 = Register Pair R1, RB

= Flag 0

= Flag 1

= Timer - 8 bits

= Interrupt Register - 8 bits

т

F0

F1

INTR

# MP Registers (Excluding Timing Chain Registers) (Continued)

| TMP Regi                                                                          | sters                                                                                                                                                                                                                                                                                                                                                                     | Ass                                     | ociated Instructions                                                                                                       | ;                                             |
|-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
|                                                                                   | CPU SEC                                                                                                                                                                                                                                                                                                                                                                   | FION (Continued)                        |                                                                                                                            |                                               |
| MASK                                                                              | = Internal Interrupt MasK — 8 bits                                                                                                                                                                                                                                                                                                                                        | *MOV MASK,A                             |                                                                                                                            |                                               |
| PSW                                                                               | = Program Status Word — 8 bits                                                                                                                                                                                                                                                                                                                                            | MOV A,PSW                               | MOV PSW,A                                                                                                                  |                                               |
| PORT                                                                              | = 8 bit I/O Port                                                                                                                                                                                                                                                                                                                                                          | ANL PORT, # data<br>ORL PORT, # data    | IN PORT<br>OUT PORT                                                                                                        |                                               |
| Miscellaneous Instructions                                                        |                                                                                                                                                                                                                                                                                                                                                                           | CALL addr<br>NOP<br>SEL MB0<br>*SEL MB3 | JMP addr<br>RET<br>SEL MB1<br>SEL RB0                                                                                      | JMPP @A<br>RETR<br>*SEL MB2<br>SEL RB1        |
|                                                                                   | VIDEO                                                                                                                                                                                                                                                                                                                                                                     | ANAGEMENT                               |                                                                                                                            |                                               |
|                                                                                   |                                                                                                                                                                                                                                                                                                                                                                           | Ass                                     | ociated Instructions                                                                                                       | •                                             |
| SCR<br>VCR<br>HOME<br>CURS                                                        | = System Control Register — 8 bits<br>= Video Control Register — 8 bits<br>= Home Address Register — 16 bits<br>= Cursor Address Register — 16 bits                                                                                                                                                                                                                       | *DEC CURS<br>*MOV CURS,A                | *MOV SCR,A<br>*MOV VCR,A<br>*MOV A,HOME<br>*INC CURS<br>*MOV A,CURS                                                        | *MOV HOME,A<br>*MOVX A,@CURS<br>*MOVX @CURS,A |
| BEGD<br>ENDD<br>SROW<br>AL0<br>AL1<br>HPEN<br>VPEN<br>VINT                        | <ul> <li>Beginning of Display RAM Register — 16 bits</li> <li>End of Display RAM Register — 16 bits</li> <li>Status Row Register — 16 bits</li> <li>Attribute Latch 0 — 8 bits</li> <li>Attribute Latch 1 — 8 bits</li> <li>Horizontal Light Pen Register — 7 bits</li> <li>Vertical Light Pen Register — 5 bits</li> <li>Vertical Interrupt Register — 5 bits</li> </ul> |                                         | *MOV BEGD,A<br>*MOV ENDD,A<br>*MOV SROW,A<br>*MOV AL0,A<br>*MOV AL1,A<br>*MOV A,HPEN<br>*MOV A,VPEN<br>*MOV VINT,A         |                                               |
|                                                                                   | UAR                                                                                                                                                                                                                                                                                                                                                                       | I CONTROL                               |                                                                                                                            |                                               |
| PSR<br>BAUD<br>UCR<br>UMX<br>STAT<br>RCVR<br>XMTR<br>TCP<br>@TCP<br>•New instruct | = Prescale Register (UART) — 8 bits<br>= Baud Rate Select Register — 8 bits<br>= UART Control Register — 8 bits<br>= UART Multiplex Register — 8 bits<br>= Status Latch (UART) — 6 bits<br>= UART Receive Buffer — 8 bits<br>= UART Transmit Buffer — 8 bits<br>= Timing Chain Pointer<br>= Register Pointed to by TCP<br>tion added to 8048 subset.                      |                                         | *MOV PSR,A<br>*MOV BAUD,A<br>*MOV UCR,A<br>*MOV UMX,A<br>*MOV A,STAT<br>*IN RCVR<br>*OUT XMTR<br>*MOV TCP,A<br>*MOV @TCP,A |                                               |

# **Symbol Definitions**

| Symbol | Definition                          |
|--------|-------------------------------------|
| AC     | Auxiliary Carry Flag                |
| addr   | Program Memory Address              |
| b      | Bit Designator (b = $0 - 7$ )       |
| BS     | RAM Bank Switch                     |
| data   | Number or Expression (8 bits)       |
| DBF    | Program Memory Bank Select Bits (2) |
| EXI    | External Interrupt Pin              |
| F0, F1 | Internal Flags                      |
| P      | I/O Port (8 bits)                   |

| Symbol   | Definition                                                       |
|----------|------------------------------------------------------------------|
| PC       | Program Counter                                                  |
| SP       | Stack Pointer                                                    |
| TF       | Timer Flag                                                       |
| #        | Prefix for Immediate Data                                        |
| @        | Prefix for Indirect Address                                      |
|          | Contents of Register                                             |
| (())     | Contents of Memory Location pointed to by<br>designated register |
| <b>←</b> | Replaced by                                                      |

| Mnemonic         | Machine Code                                   | Function                                               | Description                                                                                                              | Cycles | Butos | Flags |    |     |    |   |  |  |  |
|------------------|------------------------------------------------|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|--------|-------|-------|----|-----|----|---|--|--|--|
| Milemonic        | Machine Code                                   | Function                                               | Description                                                                                                              |        | Bytes | c     | AC | HAC | FO | F |  |  |  |
| ADD A, Rr        | 01101rr                                        | (A) $\leftarrow$ (A) + (Rr) for<br>r = 0 - 7           | Add contents of<br>designated register<br>to the Accumulator<br>(8-bit operation)                                        | 1      | 1     | •     | *  | *   |    |   |  |  |  |
| ADD A, #data     | 0 0 0 0 0 0 1 1<br>d7 d6 d5 d4 d3 d2 d1 d0     |                                                        | Add immediate the<br>specified data to the<br>Accumulator (8-bit<br>operation)                                           | 2      | 2     | •     | *  | *   |    |   |  |  |  |
| ADD A, @ Rr      | 0 1 1 0 0 0 0 r                                | (A) $\leftarrow$ (A) + ((Rr)) for<br>r = 0 - 1         | Add indirect the<br>contents of data<br>memory pointed to<br>by Rr to the<br>Accumulator (8-bit<br>operation)            | 1      | 1     | *     | •  | •   |    |   |  |  |  |
| ADDC A, Rr       | 01111rr                                        | $(A) \leftarrow (A) + (C) + (Rr)$<br>for r = 0 - 7     | Add with carry the<br>contents of the<br>designated register<br>to the Accumulator<br>(8-bit operation)                  | 1      | 1     | •     | *  | •   |    |   |  |  |  |
| ADDC A, # data   | 0 0 0 1 0 0 1 1<br>d7 d6 d5 d4 d3 d2 d1 d0     | (A) ← (A) + (C) + data                                 | Add immediate with<br>carry the specified<br>data to the<br>Accumulator (8-bit<br>operation)                             | 2      | 2     | *     | •  | •   |    |   |  |  |  |
| ADDC A, @ Rr     | 0 1 1 1 0 0 0 r                                | (A) $\leftarrow$ (A) + (C) +<br>( (Rr) ) for r = 0 - 1 | Add indirect with<br>carry the contents of<br>data memory pointed<br>to by Rr to the<br>Accumulator (8-bit<br>operation) | 1      | 1     | *     | *  | *   |    |   |  |  |  |
| ANL A, Rr        | 01011rrr                                       | (A) $\leftarrow$ (A) AND (Rr) for<br>r = 0 - 7         | Logical AND<br>contents of<br>designated register<br>with Accumulator (8-<br>bit operation)                              | 1      | 1     |       |    |     |    |   |  |  |  |
| ANL A, # data    | 0 1 0 1 0 0 1 1<br>d7 d6 d5 d4 d3 d2 d1 d0     |                                                        | Logical AND<br>specified Immediate<br>Data with<br>Accumulator (8-bit<br>operation)                                      | 2      | 2     |       |    |     |    |   |  |  |  |
| ANL A, @ Rr      | 0101000r                                       | (A) $\leftarrow$ (A) AND ((Rr))<br>for r = 0 - 1       | Logical AND indirect<br>the contents of data<br>memory pointed to<br>by Rr with<br>Accumulator (8-bit<br>operation)      | 1      | 1     |       |    |     |    |   |  |  |  |
| ANL PORT, # data | 0 1 1 1 0 0 1 1<br>d7 d6 d5 d4 d3 d2 d1 d0     |                                                        | Logical AND<br>immediate specified<br>data with output port<br>(8-bit operation)                                         | 2      | 2     |       |    |     |    |   |  |  |  |
| CALL addr        | a10 a9 a8 1 0 1 0 0<br>a7 a6 a5 a4 a3 a2 a1 a0 |                                                        | Call designated<br>subroutine                                                                                            | 2      | 2     |       |    |     |    |   |  |  |  |

7

7-31

#### . . .

| Mnemonic      | Machine Code |   |   |   |   |     |   |   | E                                                                                                                                                                                                                                                                                                                    | Description                                                                                                              | Cycles | Butes | Flags |    |      |    |    |
|---------------|--------------|---|---|---|---|-----|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|--------|-------|-------|----|------|----|----|
| Mnemonic      | machine Code |   |   |   |   | oae |   |   | Function                                                                                                                                                                                                                                                                                                             | Description                                                                                                              | Cycles | Bytes |       | AC | HACC | F0 | F1 |
| CLR A         | 0            | 0 | 1 | 0 | 0 | 1   | 1 | 1 | (A) ← 0                                                                                                                                                                                                                                                                                                              | Clear the<br>Accumulator                                                                                                 | 1      | 1     |       |    | _    |    |    |
| CLR C         | 1            | 0 | 0 | 1 | 0 | 1   | 1 | 1 | (C) ← 0                                                                                                                                                                                                                                                                                                              | Clear carry bit                                                                                                          | 1      | 1     | *     |    |      |    |    |
| CLR F0        | 1            | 0 | 0 | 0 | 0 | 1   | 0 | 1 | (FO) ← 0                                                                                                                                                                                                                                                                                                             | Clear Flag 0                                                                                                             | 1      | 1     |       |    |      | *  |    |
| CLR F1        | 1            | 0 | 1 | 0 | 0 | 1   | 0 | 1 | (F1) ← 0                                                                                                                                                                                                                                                                                                             | Clear Flag 1                                                                                                             | 1      | 1     |       |    |      |    | *  |
| CPL A         | 0            | 0 | 1 | 1 | 0 | 1   | 1 | 1 | (A) ← NOT (A)                                                                                                                                                                                                                                                                                                        | Complement the<br>contents of the<br>Accumulator (8-bit<br>operation)                                                    | 1      | 1     |       |    |      |    |    |
| CPL C         | 1            | 0 | 1 | 0 | 0 | 1   | 1 | 1 | (C) ← NOT (C)                                                                                                                                                                                                                                                                                                        | Complement carry<br>bit                                                                                                  | 1      | 1     | *     |    |      |    |    |
| CPL F0        | 1            | 0 | 0 | 1 | 0 | 1   | 0 | 1 | (F0) ← NOT (F0)                                                                                                                                                                                                                                                                                                      | Complement Flag 0                                                                                                        | 1      | 1     |       |    |      | *  |    |
| CPL F1        | 1            | 0 | 1 | 1 | 0 | 1   | 0 | 1 | (F1) ← NOT (F1)                                                                                                                                                                                                                                                                                                      | Complement Flag 1                                                                                                        | 1      | 1     |       |    |      |    | *  |
| DA A          | 0            | 1 | 0 | 1 | 0 | 1   | 1 | 1 |                                                                                                                                                                                                                                                                                                                      | Decimal Adjust the<br>contents of the<br>Accumulator (8-bit<br>operation)                                                | 1      | 1     | *     | *  |      |    |    |
| DEC A         | 0            | 0 | 0 | 0 | 0 | 1   | 1 | 1 | (HACC, A) ← (HACC,<br>A) - 1                                                                                                                                                                                                                                                                                         | Decrement by 1 the<br>contents of HACC/<br>ACC                                                                           | 1      | 1     | *     |    | *    |    |    |
| DECCURS       | 0            | 0 | 0 | 0 | 1 | 0   | 1 | 0 | (CURS) ← (CURS) – 1                                                                                                                                                                                                                                                                                                  | Decrement by 1 the<br>contents of the<br>Cursor Address<br>Register                                                      | 1      | 1     |       |    |      |    |    |
| DEC Rr        | 1            | 1 | 0 | 0 | 1 | r   | r | r | (Rr) ← (Rr) – 1                                                                                                                                                                                                                                                                                                      | Decrement by 1 the<br>contents of the<br>designated register<br>(8-bit operation)                                        | 1      | 1     | •     |    |      |    |    |
| DECL Rr       | 0            | 0 | 0 | 0 | 1 | 0   | 0 | r | $\begin{array}{l} (\mathrm{Rr}) \ \longleftarrow \ (\mathrm{Rr}) \ -1 \ \mathrm{for} \\ \mathrm{r} = 0 \ -1 \end{array}$                                                                                                                                                                                             | Decrement by 1 the<br>contents of the<br>designated 16-bit<br>register pair                                              | 1      | 1     |       |    |      |    |    |
| DIS II        | 0            | 0 | 1 | 1 | 0 | 1   | 0 | 1 |                                                                                                                                                                                                                                                                                                                      | Disable internal<br>interrupts                                                                                           | 1      | 1     |       |    |      |    |    |
| DIS XI        | 0            | 0 | 0 | 1 | 0 | 1   | 0 | 1 |                                                                                                                                                                                                                                                                                                                      | Disable external<br>interrupts                                                                                           | 1      | 1     |       |    |      |    |    |
| DJNZ Rr, addr |              |   |   |   |   |     |   |   | $\begin{array}{l} (\mathrm{Rr}) \leftarrow (\mathrm{Rr}) - 1 \ \mathrm{for} \\ \mathrm{r} = 0 - 7 \\ \mathrm{If} \ (\mathrm{Rr}) \neq 0 \ \mathrm{do} \ (\mathrm{PC0} - 7) \\ \leftarrow \ \mathrm{addr} \\ \mathrm{If} \ (\mathrm{Rr}) = 0 \ \mathrm{do} \ (\mathrm{PC}) \\ \leftarrow \mathrm{PC} + 2 \end{array}$ | Decrement the<br>specified register<br>and Jump if not zero<br>to designated<br>address within page<br>(8-bit decrement) | 2      | 2     |       |    |      |    |    |
| EN II         | 0            | 0 | 1 | 0 | 0 | 1   | 0 | 1 |                                                                                                                                                                                                                                                                                                                      | Enable internal<br>interrupts.                                                                                           | 1      | 1     |       |    |      |    |    |
| EN XI         | 0            | 0 | 0 | 0 | 0 | 1   | 0 | 1 |                                                                                                                                                                                                                                                                                                                      | Enable external<br>interrupt.                                                                                            | 1      | 1     |       |    |      |    |    |
| INC A         | 0            | 0 | 0 | 1 | 0 | 1   | 1 | 1 | (HACC, A) ← (HACC,<br>A) + 1                                                                                                                                                                                                                                                                                         | Increment by 1 the contents of HACC/A.                                                                                   | 1      | 1     | *     |    | *    |    |    |
| INC CURS      | 0            | 0 | 1 | 1 | 1 | 0   | 1 | 0 | (CURS) ← (CURS) + 1                                                                                                                                                                                                                                                                                                  | Increment by 1 the<br>contents of the<br>Cursor Address<br>Register.                                                     | 1      | 1     |       |    |      |    |    |

| Mnemonic  |           |          | Mac     | hin.    |   |         |   |   | Function                                                                                                                                                      | Description                                                                                                                          | Cycles | Dutes |   |    | Flags |    |   |
|-----------|-----------|----------|---------|---------|---|---------|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--------|-------|---|----|-------|----|---|
| witemotic |           |          | viac    | 11114   |   | Jue     |   |   | Function                                                                                                                                                      | Description                                                                                                                          | Cycles | Dytes | С | AC | HACC  | F0 | F |
| INC Rr    | 0         | 0        | 0       | 1       | 1 | r       | r | r | $(\operatorname{Rr}) \leftarrow (\operatorname{Rr}) + 1 \text{ for}$<br>r = 0 - 7                                                                             | Increment by 1 the<br>contents of the<br>designated register<br>(8-bit increment)                                                    | 1      | 1     | * |    |       |    |   |
| INC @ Rr  | 0         | 0        | 0       | 1       | 0 | 0       | 0 | r | ((Rr)) ← ((Rr)) + 1 for<br>r = 0 - 1                                                                                                                          | Increment in direct<br>the contents of data<br>memory pointed to<br>by Rr (8-bit<br>increment)                                       | 1      | 1     | * |    |       |    |   |
| INCL Rr   | 0         | 0        | 1       | 1       | 1 | 0       | 0 | r | $(\operatorname{Rr}) \leftarrow (\operatorname{Rr}) + 1 \text{ for}$<br>r = 0 - 1                                                                             | Increment by 1 the<br>contents of the<br>designated 16-bit<br>register pair                                                          | 1      | 1     |   |    |       |    |   |
| IN PORT   | 1         | 1        | 1       | 0       | 0 | 0       | 0 | 1 | (A) ← (P)                                                                                                                                                     | Input data from port<br>into Accumulator<br>(8-bit transfer)                                                                         | 2      | 1     |   |    |       |    |   |
| IN RCVR   | 1         | 1        | 1       | 0       | 0 | 0       | 0 | 0 | (A) ← (RCVR)                                                                                                                                                  | Input contents of<br>UART Receive buffer<br>into Accumulator (8-<br>bit transfer). Also,<br>clears Receive<br>Buffer Full interrupt. | 1      | 1     |   |    |       |    |   |
| JBb addr  |           | b1<br>a6 |         |         |   |         |   |   | $\begin{array}{l} (PC0-7) \longleftarrow addr \text{ if} \\ (b) = 1 \\ (PC) \longleftarrow (PC) + 2 \text{ if} \\ (b) = 0 \text{ for } b = 0 - 7 \end{array}$ | Jump to specified<br>address within page<br>if Accumulator bit is<br>set                                                             | 2      | 2     |   |    |       |    |   |
| JC addr   | 1<br>a7   | 1<br>a6  |         |         |   | 1<br>a2 |   |   | $(PC0-7) \leftarrow addr \text{ if} \\ C = 1 \\ (PC) \leftarrow (PC) + 2 \text{ if} \\ C = 0$                                                                 | Jump to specified<br>address within page<br>if Carry flag is set                                                                     | 2      | 2     |   |    |       |    |   |
| JF0 addr  | 1<br>a7   | 0<br>a6  | -       | 1<br>a4 | - | 1<br>a2 |   |   | $(PC0-7) \leftarrow addr \text{ if}$ $F0 = 1$ $(PC) \leftarrow (PC) + 2 \text{ if}$ $F0 = 0$                                                                  | Jump to specified<br>address within page<br>if Flag F0 is set                                                                        | 2      | 2     |   |    |       |    |   |
| JF1 addr  | 0<br>a7   | 1<br>a6  | 1<br>a5 | 1<br>a4 |   | 1<br>a2 |   |   | $(PC0-7) \leftarrow addr \text{ if}$<br>F1 = 1<br>$(PC) \leftarrow (PC) + 2 \text{ if}$<br>F1 = 0                                                             | Jump to specified<br>address within page<br>if Flag F1 is set                                                                        | 2      | 2     |   |    |       |    |   |
| JMP addr  | a10<br>a7 |          |         |         | - | 1<br>a2 | - | - | $\begin{array}{l} (PC8-10) \leftarrow addr 8-10 \\ (PC0-7) \leftarrow addr 0-7 \\ (PC11-12) \leftarrow DBF 0, 1 \end{array}$                                  | Direct Jump to<br>specified address<br>within 2k Bank                                                                                | 2      | 2     |   |    |       |    |   |
| JMPP @ A  | 1         | 0        | 1       | 0       | 0 | 0       | 1 | 1 | (PC0-7) ← ((A))                                                                                                                                               | Jump indirect within<br>page to the address<br>specified in the<br>memory location<br>pointed to by the<br>Accumulator               | 2      | 1     |   |    |       |    |   |
| JNC addr  | 1<br>a7   | 1<br>a6  |         |         |   |         |   |   | $(PC0-7) \leftarrow addr$ if C = 0 $(PC) \leftarrow (PC) + 2$ if C = 1                                                                                        | Jump within page to<br>specified address if<br>Carry flag is 0                                                                       | 2      | 2     |   |    |       |    |   |

7

# Instruction Set (Continued)

| Mnemonic    | Τ        |   | N | lac | hin     | e C | ode     |         |         | Function                                                                                                                                        | Description                                                                                                          | Cycles | Bytes |   |    | Flags |    |    |
|-------------|----------|---|---|-----|---------|-----|---------|---------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|--------|-------|---|----|-------|----|----|
|             |          |   |   |     |         |     |         |         |         |                                                                                                                                                 | Description                                                                                                          | Cycles | Dytes | С | AC | HACC  | F0 | F1 |
| JNF0 addr   | 1<br>a7  |   |   |     |         |     |         | 1<br>a1 |         | $(PC0-7) \leftarrow addr \text{ if}$<br>F0 = 0<br>$(PC) \leftarrow (PC) + 2 \text{ if}$<br>F0 = 1                                               | Jump within page to<br>specified address if<br>F0 is 0                                                               | 2      | 2     |   |    |       |    |    |
| JNF1 addr   | 0<br>a7  |   |   |     |         |     |         | 1<br>a1 |         | $(PC0-7) \leftarrow addr \text{ if}$<br>F1 = 0<br>$(PC) \leftarrow (PC) + 2 \text{ if}$<br>F1 = 1                                               | Jump within page to<br>specified address if<br>F1 is 0                                                               | 2      | 2     |   |    |       | i  |    |
| JNTF addr   |          |   |   |     |         |     |         | 1<br>a1 | 0<br>a0 | $\begin{array}{l} (PC0-7) \leftarrow addr \text{ if} \\ TF = 0 \\ (PC) \leftarrow (PC) + 2 \text{ if} \\ TF = 1, (TF) \leftarrow 0 \end{array}$ | Jump within page to<br>specified address if<br>Timer flag is reset. If<br>not, continue and<br>reset TF              | 2      | 2     |   |    |       |    |    |
| JNXI addr   |          |   |   |     |         |     |         | 1<br>a1 |         | $(PC0-7) \leftarrow addr \text{ if}$<br>EXI = LOW<br>$(PC) \leftarrow (PC) + 2 \text{ if}$<br>EXI = HIGH                                        | Jump within page to<br>specified address if<br>External Interrupt pin<br>is LOW                                      | 2      | 2     |   |    |       |    |    |
| JNZ addr    | 1<br> a7 | - |   | -   | 1<br>a4 |     |         | 1<br>a1 |         | $(PC0-7) \leftarrow addr \text{ if}$ $A \neq 0$ $(PC) \leftarrow (PC) + 2 \text{ if}$ $A = 0$                                                   | Jump within page to<br>specified address if<br>Accumulator is not 0                                                  | 2      | 2     |   |    |       |    |    |
| JTF addr    | 0<br>a7  |   |   |     |         |     | 1<br>a2 |         | 0<br>a0 | $\begin{array}{l} (PC0-7) \leftarrow addr \text{ if} \\ TF = 1, (TF) \leftarrow 0 \\ (PC) \leftarrow (PC) + 2 \text{ if} \\ TF = 0 \end{array}$ | Jump within page to<br>specified address if<br>Timer flag is set. If<br>jump taken Timer<br>flag reset               | 2      | 2     |   |    |       |    |    |
| JXI addr    | 1<br>a7  |   |   | -   |         |     |         | 1<br>a1 |         | $(PC0-7) \leftarrow addr if$<br>EXI = HIGH<br>$(PC) \leftarrow (PC) + 2 if$<br>EXI = LOW                                                        | Jump within page to<br>specified address if<br>External Interrupt pin<br>is HIGH                                     | 2      | 2     |   |    |       |    |    |
| JZ addr     | 1<br> a7 |   |   |     |         |     |         | 1<br>a1 |         | $(PC0-7) \leftarrow addr if$<br>A = 0<br>$(PC) \leftarrow (PC) + 2 if$<br>$A \neq 0$                                                            | Jump within page to<br>specified address if<br>Accumulator is 0                                                      | 2      | 2     | ľ |    |       |    |    |
| MOV A, CURS | 1        | C | ) | 0   | 1       | 1   | 0       | 1       | 1       | (HACC/A) ← (CURS)                                                                                                                               | Copy the contents of<br>the Cursor Address<br>Register into the<br>HACC/A (16-bit<br>transfer)                       | 1      | 1     |   |    | *     |    |    |
| MOV A, HACC | 1        | 1 |   | 1   | 0       | 0   | 0       | 1       | 0       | (A) ← (HACC)                                                                                                                                    | Copy contents of the<br>High Accumulator<br>into the Low<br>Accumulator (8-bit<br>transfer)                          | 1      | 1     |   |    |       |    |    |
| MOV A, HOME | 1        | C | ) | 0   | 1       | 1   | 0       | 1       | 0       | (HACC/A) ← (HOME)                                                                                                                               | Copy the contents of<br>the Home Address<br>register into the<br>HACC/A (16-bit<br>transfer)                         | 1      | 1     |   |    | *     |    |    |
| MOV A, HPEN | 0        | C | ) | 1   | 1       | 1   | 1       | 1       | 1       | (A0-6) ← (HPEN)<br>(A7) ← O                                                                                                                     | Copy the contents of<br>the Horizontal Light<br>Pen Register into the<br>Accumulator (7-bit<br>transfer, A7 cleared) |        | 1     |   |    |       |    |    |

| Mnemonic      | Machine Code                               | Function                        | Description                                                                                                          | Cycles | Butes | Flags |    |      |      |  |  |
|---------------|--------------------------------------------|---------------------------------|----------------------------------------------------------------------------------------------------------------------|--------|-------|-------|----|------|------|--|--|
|               | macrime code                               |                                 | Description                                                                                                          | Oycles | Dytes | С     | AC | насс | F0 F |  |  |
| MOV A, INTR   | 1 0 0 0 1 1 0 0                            | (A) ← (INTR)                    | Copy the contents of<br>the Interrupt Register<br>into the Accumulator<br>(8-bit transfer)                           | 1      | 1     |       |    |      |      |  |  |
| MOV A, PSW    | 1 1 0 0 0 1 1 1                            |                                 | Copy contents of the<br>Program Status word<br>into the Accumulator<br>(8-bit transfer)                              | 1      | 1     |       |    |      |      |  |  |
| MOV A, Rr     | 11111 г г г                                | (A) ← (Rr)<br>for r = 0 − 7     | Copy the contents of<br>the designated<br>Register into the<br>Accumulator (8-bit<br>transfer)                       |        |       |       |    |      |      |  |  |
| MOV A, STAT   | 10011100                                   | (A0–5) ← (STAT)<br>(A6–7) ← 11  | Copy the contents of<br>the UART Status Latch<br>into the Accumulator<br>(6-bit transfer, A6 and<br>A7 set)          | 1      | 1     |       |    |      |      |  |  |
| MOV A, T      | 0 1 0 0 0 0 1 0                            | (A) ← (T)                       | Copy the contents of<br>the Timer into the<br>Accumulator (8-bit<br>transfer)                                        | 1      | 1     |       |    |      |      |  |  |
| MOV A, VPEN   | 00111110                                   | (A0-4) ← (VPEN)<br>(A5-7) ← O   | Copy contents of the<br>Vertical Light Pen<br>Register into the<br>Accumulator (5-bit<br>transfer, A5–A7<br>cleared) | 1      | 1     |       |    |      |      |  |  |
| MOV A, @ Rr   | 1 1 1 1 0 0 0 r                            | (A) ← ( (Rr) ) for<br>r = 0 − 1 | Copy indirect the<br>contents of data<br>memory pointed to by<br>Rr into the<br>Accumulator (8-bit<br>transfer)      | 1      | 1     |       |    |      |      |  |  |
| MOV A, # data | 0 0 1 0 0 0 1 1<br>d7 d6 d5 d4 d3 d2 d1 d0 |                                 | Load immediate the<br>specified data into the<br>Accumulator (8-bit<br>load)                                         | 2      | 2     |       |    |      |      |  |  |
| MOV ALO, A    | 0 0 1 1 1 1 0 0                            | (ALO) ← (A)                     | Copy the contents of<br>the Accumulator into<br>Attribute Latch 0 (8-bit<br>transfer)                                | 1      | 1     |       |    |      |      |  |  |
| MOV AL1, A    | 0 0 1 1 1 1 0 1                            | (AL1) ← (A)                     | Copy the contents of<br>the Accumulator into<br>Attribute Latch 1 (8-bit<br>transfer)                                | 1      | 1     |       |    |      |      |  |  |
| MOV BAUD, A   | 0 0 0 0 0 0 1 0                            | (BAUD) ← (A)                    | Copy the contents of<br>the Accumulator into<br>the UART Baud Rate<br>Select Register (8-bit<br>transfer)            | 1      | 1     |       |    |      |      |  |  |
| MOV BEGD, A   | 00001101                                   | (BEGD) ← (HACC/A)               | Copy the contents of<br>HACC/A into the<br>Beginning of Display<br>RAM Register (16-bit<br>transfer)                 | 1      | 1     |       |    |      |      |  |  |

7

| Mnemonic    |              |   | Mar | hin | • 0 | ode |   |          | Function                    | Description                                                                                     | Cycles | Bytes | Flags |      |     |  |  |  |
|-------------|--------------|---|-----|-----|-----|-----|---|----------|-----------------------------|-------------------------------------------------------------------------------------------------|--------|-------|-------|------|-----|--|--|--|
|             | Machine Code |   |     |     | oue |     | _ | Function | Description                 | Cycles                                                                                          | Dytes  | С     | AC    | HACC | FOF |  |  |  |
| MOV CURS, A | 1            | 0 | 0   | 0   | 1   | 0   | 1 | 1        | (CURS) ← (HACC/A)           | Copy the contents of<br>HACC/A into the<br>Cursor Address<br>Register (16-bit<br>transfer)      | 1      | 1     |       |      |     |  |  |  |
| MOV ENDD, A | 0            | 0 | 0   | 0   | 1   | 1   | 0 | 0        | (ENDD) ← (HACC/A)           | Copy the contents of<br>HACC/A into the End<br>of Display RAM<br>Register (16-bit<br>transfer)  | 1      | 1     |       |      |     |  |  |  |
| MOV HACC, A | 1            | 1 | 0   | 0   | 0   | 0   | 1 | 0        | (HACC) ← (A)                | Copy the contents of<br>the Low Accumulator<br>into the High<br>Accumulator (8-bit<br>transfer) | 1      | 1     |       |      | •   |  |  |  |
| MOV HOME, A | 1            | 0 | 0   | 0   | 1   | 0   | 1 | 0        | (HOME) ← (HACC/A)           | Copy the contents of<br>HACC/A into the<br>Home Address<br>Register (16-bit<br>transfer)        | 1      | 1     |       |      |     |  |  |  |
| MOV MASK, A | 1            | 0 | 0   | 0   | 0   | 0   | 1 | 0        | (MASK) ← (A)                | Copy the contents of<br>the Accumulator into<br>the Interrupt Mask<br>Register (8-bit transfer) | 1      | 1     |       |      |     |  |  |  |
| MOV PSR, A  | 0            | 0 | 1   | 0   | 0   | 0   | 1 | 0        | (PSR) ← (A)                 | Copy the contents of<br>the Accumulator into<br>the UART Prescale<br>Register (8-bit transfer)  | 1      | 1     |       |      |     |  |  |  |
| MOV PSW, A  | 1            | 1 | 0   | 1   | 0   | 1   | 1 | 1        | (PSW) ← (A)                 | Copy contents of the<br>Accumulator into the<br>Program Status Word<br>(8-bit transfer)         | 1      | 1     | *     | •    |     |  |  |  |
| MOV Rr, A   | 1            | 0 | 1   | 0   | 1   | r   | r | r        | (Rr) ← (A) for<br>r = 0 - 7 | Copy contents of the<br>Accumulator into the<br>designated register (8-<br>bit transfer)        | 1      | 1     |       |      |     |  |  |  |
| MOV SCR, A  | 0            | 1 | 0   | 1   | 0   | 1   | 0 | 1        | (SCR) ← (A)                 | Copy contents of the<br>Accumulator into the<br>System Control<br>Register (8-bit transfer)     | 1      | 1     |       |      |     |  |  |  |
| MOV SROW, A | 0            | 0 | 0   | 0   | 1   | 1   | 1 | 0        | (SROW) ← (HACC/A)           | Copy the contents of<br>HACC/A into the<br>Status Row Register<br>(16-bit transfer)             | 1      | 1     |       |      |     |  |  |  |
| MOV T, A    | 0            | 1 | 1   | 0   | 0   | 0   | 1 | 0        | (A) → (T)                   | Copy the contents of<br>the Accumulator into<br>the Timer (8-bit<br>transfer)                   | 1      | 1     |       |      |     |  |  |  |
| MOV TCP, A  | 1            | 0 | 0   | 0   | 0   | 1   | 1 | 1        | (TCP) ← (A)                 | Copy the contents of<br>the Accumulator into<br>the Timing Chain<br>Pointer                     | 1      | 1     |       |      |     |  |  |  |

| Mnemonic         |         |         | Jac     | hin     | e C     | ode     |         |         | Func                       | ion Description                                                                                                    | n Cycle             | Bytes |   |    | Flags |    |    |
|------------------|---------|---------|---------|---------|---------|---------|---------|---------|----------------------------|--------------------------------------------------------------------------------------------------------------------|---------------------|-------|---|----|-------|----|----|
|                  |         |         |         |         |         |         |         |         | T dilo                     | Besonption                                                                                                         | , oyolo             | ,     | С | AC | HACC  | F0 | F1 |
| MOV UCR, A       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 1       | (UCR) ← (A)                | Copy the content<br>the Accumulator<br>the UART Contro<br>Register (8-bit tra                                      | into<br>I           | 1     |   |    |       |    |    |
| MOV VCR, A       | 0       | 1       | 0       | 0       | 0       | 1       | 0       | 1       | (VCR) ← (A)                | Copy the content<br>the Accumulator<br>the Video Contro<br>Register (8-bit tra                                     | into<br>I           | 1     |   |    |       |    |    |
| MOV VINT, A      | 1       | 0       | 1       | 0       | 0       | 0       | 1       | 0       | (VINT) ← (A                | Copy the content<br>the Accumulator<br>the Vertical Inter<br>Register                                              | into                | 1     |   |    |       |    |    |
| MOV Rr, # data   | 1<br>d7 | 0<br>d6 | 1<br>d5 | 1<br>d4 | 1<br>d3 | r<br>d2 | r<br>d1 | r<br>d0 | (Rr) ← data<br>r = 0 - 7   | for Load immediate<br>specified data int<br>designated regis<br>bit load)                                          | o the               | 2     |   |    |       |    |    |
| MOV @ Rr, A      | 1       | 0       | 1       | 0       | 0       | 0       | 0       | r       | ( (Rr) ) ← (A<br>r = 0 − 1 | for Copy indirect the<br>contents of the<br>Accumulator into<br>data memory loc<br>pointed to by Rr<br>transfer)   | the<br>ation        | 1     |   |    |       |    |    |
| MOV @ Rr, # data | 1<br>d7 | 0<br>d6 | 1<br>d5 | 1<br>d4 | 0<br>d3 | 0<br>d2 | 0<br>d1 | r<br>d0 | ((Rr)) ← da<br>r = 0 - 1   | ta for Load indirect the<br>specified immedi<br>data into the data<br>memory location<br>pointed to by Rr<br>load) | ate<br>1            | 2     |   |    |       |    |    |
| MOV @ TCP, A     | 1       | 0       | 1       | 1       | 0       | 1       | 1       | 1       | ((TCP)) ← (<br>(TCP) ← (TC |                                                                                                                    | the<br>gister<br>⊃. | 1     |   |    |       |    |    |
| MOV UMX, A       | 0       | 0       | 1       | 1       | 0       | 0       | 1       | 1       | (UMX) ← (A                 | Copy the conten<br>the Accumulator<br>the UART Multip<br>Register (8-bit tra                                       | into<br>ex          | 1     |   |    |       |    |    |
| MOVL A, RO       | 1       | 0       | 0       | 1       | 1       | 0       | 0       | 0       | (HACC/A) ←                 | - (RA, R0) Copy the conten<br>RA, R0 into HAC<br>(16-bit transfer)                                                 |                     | 1     |   |    | *     |    |    |
| MOVL A, R1       | 1       | 0       | 0       | 1       | 1       | 0       | 0       | 1       | (HACC/A) ←                 | - (RB, R1) Copy the conten<br>RB, R1 into HAC<br>(16-bit transfer)                                                 | ts of 1<br>C/A      | 1     |   |    | *     |    |    |
| MOVL R0, A       | 1       | 0       | 0       | 0       | 1       | 0       | 0       | 0       | (RA, R0) ←                 | HACC/A) Copy the conten<br>HACC/A into RA<br>(16-bit transfer)                                                     |                     | 1     |   |    |       |    |    |
| MOVL R1, A       | 1       | 0       | 0       | 0       | 1       | 0       | 0       | 1       | (RB, R1) ←                 | HACC/A) Copy the conten<br>HACC/A into RB<br>(16-bit transfer)                                                     |                     | 1     |   |    |       |    |    |

| ഹ |  |
|---|--|
| 0 |  |
| 4 |  |
| Ś |  |
| z |  |

| Mnemonic       | 1 | 1 | Mad | hin | ne C | ode | • |   | Function                                                               | Description                                                                                                                                                                                                                                                              | Cycles | Bytes |   |    | Flags |      |
|----------------|---|---|-----|-----|------|-----|---|---|------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|---|----|-------|------|
|                |   |   |     |     |      |     |   |   |                                                                        |                                                                                                                                                                                                                                                                          | -,     | -,    | С | AC | HACC  | F0 F |
| Movp A, @ A    | 1 | 0 | 1   | 1   | 0    | 0   | 1 | 1 | (PC0-7) ← (A)<br>(A) ← ( (PC) )<br>(PC0-7) ← (old PC0-7)<br>+ 1        | Replace low 8 bits of<br>PC with A. Load<br>indirect within page the<br>contents of the<br>memory location<br>pointed to by new PC<br>into Accumulator.<br>Restore PC with old<br>value plus 1. Operates<br>in all memory banks.                                         | 2      | 1     |   |    |       |      |
| MOVP3 A, @ A   | 1 | 1 | 1   | 1   | 0    | 0   | 1 | 1 | (PC0-7) ← (A)<br>(PC8-10) ← 011<br>(A) ← ((PC))<br>(PC) ← (old PC) + 1 | Replace low 8 bits of<br>PC with A. Next 3 bits<br>replaced with 011.<br>Load indirect within<br>page 3 the contents of<br>the memory location<br>pointed to by new PC<br>into the Accumulator.<br>Restore PC with old<br>value plus 1. Operates<br>in all memory banks. | 2      | 1     |   |    |       |      |
| MOVX A, @ CURS | 1 | 0 | 0   | 1   | 1    | 1   | 0 | 1 | (HACC/A) ← ( (CURS) )                                                  | Copy indirect the<br>contents of display<br>memory as pointed to<br>by CURS into HACC/A<br>(16-bit transfer)                                                                                                                                                             | Min. 2 | 1     |   |    | *     |      |
| MOVX A, @ R0   | 1 | 0 | 0   | 1   | 0    | 0   | 0 | 0 | (HACC/A) ← ( (RA, R0) )                                                | Copy indirect the<br>contents of display<br>memory as pointed to<br>by RA, R0 into HACC/<br>A (16-bit transfer)                                                                                                                                                          | Min. 2 | 1     |   |    | •     |      |
| MOVX A, @ R1   | 1 | 0 | 0   | 1   | 0    | 0   | 0 | 1 | (HACC/A) ← ( (RB, R1) )                                                | Copy indirect the<br>contents of display<br>memory as pointed to<br>by RB, R1 into HACC/<br>A (16-bit transfer)                                                                                                                                                          | Min. 2 | 1     |   |    | *     |      |
| MOVX @ CURS, A | 1 | 0 | 0   | 0   | 1    | 1   | 0 | 1 | ( (CURS) ) ← (HACC/A)                                                  | Copy indirect the<br>contents of HACC/A<br>into the display<br>memory location as<br>pointed to by CURS<br>(16-bit transfer)                                                                                                                                             | Min. 2 | 1     |   |    |       |      |
| MOVX @ R0, A   | 1 | 0 | 0   | 0   | 0    | 0   | 0 | 0 | ( (RA, R0) ) ← (HACC/A                                                 | Copy indirect the<br>contents of HACC/A<br>into the display<br>memory location as<br>pointed to by RA, R0<br>(16-bit transfer)                                                                                                                                           | Min. 2 | 1     |   |    |       |      |

| Mnemonic         |   | 1 |      | hin | ~ ~ | ode     |   |   | Function                                                                                                    | Description                                                                                                                                     | Cycles | Buton | l |    | Flags |      |
|------------------|---|---|------|-----|-----|---------|---|---|-------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|---|----|-------|------|
| MITEMOTIC        |   |   | viau |     | eu  | oue     | 2 |   | Function                                                                                                    | Description                                                                                                                                     | Cycles | Dytes | С | AC | HACC  | F0 F |
| MOVX @ R1, A     | 1 | 0 | 0    | 0   | 0   | 0       | 0 | 1 | ( (RB, R1) ) ← (HACC/A)                                                                                     | Copy indirect the<br>contents of HACC/A<br>into the display<br>memory location<br>pointed to by RB, R1<br>(16-bit transfer)                     | Min. 2 | 1     |   |    |       |      |
| NOP              | 0 | 0 | 0    | 0   | 0   | 0       | 0 | 0 |                                                                                                             | No Operation                                                                                                                                    | 1      | 1     |   |    |       | h    |
| ORL A, Rr        | 0 | 1 | 0    | 0   | 1   | r       | r | r | (A) $\leftarrow$ (A) OR (Rr) for<br>r = 0 - 7                                                               | Logical OR contents of<br>designated register<br>with Accumulator (8-bit<br>transfer)                                                           |        | 1     |   |    |       |      |
| ORL A, @ Rr      | 0 | 1 | 0    | 0   | 0   | 0       | 0 | r | (A) $\leftarrow$ (A) OR ((Rr))<br>for r = 0 - 1                                                             | Logical OR indirect the<br>contents of the data<br>memory location<br>pointed to by Rr with<br>Accumulator (8-bit<br>operation)                 | 1      | 1     |   |    |       |      |
| ORL A, # data    |   |   |      |     |     | 0<br>d2 |   |   | (A) ← (A) OR data                                                                                           | Logical OR the<br>specified immediate<br>data with the<br>Accumulator (8-bit<br>operation)                                                      | 2      | 2     |   |    |       |      |
| ORL PORT, # data |   |   |      |     |     | 0<br>d2 |   |   | (P) ← (P) OR data                                                                                           | Logical OR immediate<br>specified data with<br>output port                                                                                      | 2      | 2     |   |    |       |      |
| OUT PORT         | 1 | 1 | 0    | 0   | 0   | 0       | 0 | 1 | (P) ← (A)                                                                                                   | Output the contents of<br>the Accumulator to the<br>I/O Port (8-bit transfer)                                                                   | 2      | 1     |   |    |       |      |
| OUT XMTR         | 1 | 1 | 0    | 0   | 0   | 0       | 0 | 0 | (XMTR) ← (A)                                                                                                | Copy the contents of<br>the Accumulator into<br>the UART Transmit<br>Buffer (8-bit transfer).<br>Also clears Transmit<br>Buffer empty interrupt | 1      | 1     |   |    |       |      |
| RET              | 1 | 0 | 0    | 0   | 0   | 0       | 1 | 1 | (SP) ← (SP) - 1<br>(PC0-12) ← ((SP))                                                                        | Return from subroutine<br>without restoring<br>Program Status Word<br>bits 5–7                                                                  | 2      | 1     |   |    |       |      |
| RETR             | 1 | 0 | 0    | 1   | 0   | 0       | 1 | 1 | (SP) ← (SP) - 1<br>(PC0-12) ← ((SP))<br>(PSW 3-7) ← ((SP))                                                  | Return from<br>Subroutine restoring<br>Program Status Word<br>(use for all returns from<br>interrupts)                                          | 2      | 1     | • | *  |       |      |
| RLA              | 1 | 1 | 1    | 0   | 0   | 1       | 1 | 1 | $\begin{array}{l} (A_{n + 1}) \leftarrow (An) \\ \text{for } n = 0 - 6 \\ (A0) \leftarrow (A7) \end{array}$ | Rotate Accumulator<br>left by 1 bit without<br>carry                                                                                            | 1      | 1     |   |    |       |      |
| RLC A            | 1 | 1 | 1    | 1   | 0   | 1       | 1 | 1 | $(A_n + 1) \leftarrow (A_n)$ for<br>n = 0 - 6<br>$(A0) \leftarrow (C)$<br>$(C) \leftarrow (A7)$             | Rotate Accumulator<br>left by 1 bit through<br>carry                                                                                            | • 1    | 1     | * |    |       |      |

| Mnemonic      | Machine Code |   |     |                                         |   |     |   |   | Function Description                                                                                                                                                                                            |                                                                                                                                   |         | Bytes |   |    | Flags |    |   |
|---------------|--------------|---|-----|-----------------------------------------|---|-----|---|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|---------|-------|---|----|-------|----|---|
| Witchiolito   |              |   | 144 | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |   | Juc |   |   | T dheabh                                                                                                                                                                                                        | Beschption                                                                                                                        | Cy oles | Dyico | С | AC | HACC  | F0 | F |
| RR A          | 0            | 1 | 1   | 1                                       | 0 | 1   | 1 | 1 | $(An) \leftarrow A_{n + 1}$ for n = 0 - 6                                                                                                                                                                       | Rotate Accumulator<br>right by 1 bit without<br>carry                                                                             | 1       | 1     |   |    |       |    |   |
| RRC A         | 0            | 1 | 1   | 0                                       | 0 | 1   | 1 | 1 | $\begin{array}{rcl} (\text{An}) & \longleftarrow & \text{A}_{n \ + \ 1} \\ \text{for } n \ = \ 0 \ - \ 6 \\ (\text{A7}) \ \longleftarrow \ (\text{C}) \\ (\text{C}) \ \longleftarrow \ (\text{A0}) \end{array}$ | Rotate Accumulator<br>right by 1 bit through<br>carry                                                                             | 1       | 1     | * |    |       |    |   |
| SEL MB0       | 1            | 1 | 0   | 0                                       | 0 | 1   | 0 | 1 | (DBF) ← 00                                                                                                                                                                                                      | Select Bank 0<br>(0–2047) of Program<br>Memory                                                                                    | 1       | 1     |   |    |       |    |   |
| SEL MB1       | 1            | 1 | 0   | 1                                       | 0 | 1   | 0 | 1 | (DBF) ← 01                                                                                                                                                                                                      | Select Bank 1<br>(2048–4095) of<br>Program Memory                                                                                 | 1       | 1     |   |    |       |    |   |
| SEL MB2       | 1            | 1 | 1   | 0                                       | 0 | 1   | 0 | 1 | (DBF) ← 10                                                                                                                                                                                                      | Select Bank 2<br>(4096–6143) of<br>Program Memory                                                                                 | 1       | 1     |   |    |       |    |   |
| SEL MB3       | 1            | 1 | 1   | 1                                       | 0 | 1   | 0 | 1 | (DBF) ← 11                                                                                                                                                                                                      | Select Bank 3<br>(6144–8191) of<br>Program Memory                                                                                 | 1       | 1     |   |    |       |    |   |
| SEL RBn       | 1            | 1 | n   | 0                                       | 0 | 0   | 1 | 1 | (BS) ← n<br>for n = 0 − 1                                                                                                                                                                                       | Select Data RAM Bank<br>(0-7) or 1 (24-31)                                                                                        | 1       | 1     |   |    |       |    |   |
| STOP T        | 0            | 1 | 1   | 0                                       | 0 | 1   | 0 | 1 |                                                                                                                                                                                                                 | Stop Timer                                                                                                                        | 1       | 1     |   |    |       |    |   |
| STRT T        | 0            | 1 | 1   | 1                                       | 0 | 1   | 0 | 1 |                                                                                                                                                                                                                 | Start Timer                                                                                                                       | 1       | 1     |   |    |       |    |   |
| SWAP A        | 0            | 1 | 0   | 0                                       | 0 | 1   | 1 | 1 | (A4-A7) ↔ (A0-A3)                                                                                                                                                                                               | SWAP 4 bit nibbles in<br>Accumulator                                                                                              | 1       | 1     |   |    |       |    |   |
| XCH A, Rr     | 0            | 0 | 1   | 0                                       | 1 | r   | r | r | (A) $\longleftrightarrow$ (Rr)<br>for r = 0 - 7                                                                                                                                                                 | Exchange the<br>Accumulator and<br>contents of designated<br>register (8-bit transfer)                                            | 1       | 1     |   |    |       |    |   |
| XCH A, @ Rr   | 0            | 0 | 1   | 0                                       | 0 | 0   | 0 | r | $(A) \longleftrightarrow ((Rr))$<br>for $r = 0 - 1$                                                                                                                                                             | Exchange indirect the<br>contents of the<br>Accumulator and the<br>data memory location<br>pointed to by Rr (8-bit<br>transfer)   | 1       | 1     |   |    |       |    | - |
| XCHD A, @ Rr  | 0            | 0 | 1   | 1                                       | 0 | 0   | 0 | r | $(A0-3) \leftrightarrow ((Rr)) 0-3$<br>for r = 0 - 1                                                                                                                                                            | Exchange indirect the<br>low 4 bits of the<br>Accumulator and the<br>data memory location<br>pointed to by Rr (4-bit<br>transfer) | 1       | 1     |   |    |       |    |   |
| XRL A, Rr     | 1            | 1 | 0   | 1                                       | 1 | r   | r |   | (A) $\leftarrow$ (A) XOR (Rr)<br>for r = 0 - 7                                                                                                                                                                  | Logical XOR contents<br>of designated register<br>with Accumulator (8-bit<br>transfer)                                            | 1       | 1     |   |    |       |    |   |
| XRL A, @ Rr   | 1            | 1 | 0   | 1                                       | 0 | 0   | 0 | r | (A) $\leftarrow$ (A) XOR ((Rr))<br>for r = 0 - 1                                                                                                                                                                | Logical XOR indirect<br>the contents of the<br>data memory location<br>pointed to by Rr with<br>the Accumulator                   | 1       | 1     |   |    |       |    |   |
| XRL A, # data |              |   |     | 1<br>d4                                 |   |     |   |   | (A) ← (A) XOR data                                                                                                                                                                                              | Logical XOR the<br>immediate specified<br>data with the<br>Accumulator                                                            | 2       | 2     |   |    |       |    |   |

| ΤN          | IP Oj                | pcod                 | le Ch             | art                   |                     |                  |      |                   |                     |                     |                     |                     |                     |                      |                     |                     |
|-------------|----------------------|----------------------|-------------------|-----------------------|---------------------|------------------|------|-------------------|---------------------|---------------------|---------------------|---------------------|---------------------|----------------------|---------------------|---------------------|
|             | 0                    | 1                    | 2                 | 3                     | 4                   | 5                | 6    | 7                 | SN<br>8             | 9                   | Α                   | в                   | с                   | D                    | Е                   | F                   |
| 0           | NOP                  | MOV<br>UCR,<br>A     | MOV<br>BAUD,<br>A | ADD<br>A,<br>#data    | JMP<br>(page<br>0)  | EN<br>XI         | JNTF | DEC A             | DECL<br>R0          | DECL<br>R1          | DEC<br>CURS         |                     | MOV<br>ENDD,<br>A   | MOV<br>BECD,<br>A    | MOV<br>SROW,<br>A   |                     |
| 1           | INC<br>@R0           | INC<br>@R1           | JB0               | ADDC<br>A,<br>#data   | CALL<br>(page<br>0) | DIS<br>XI        | JTF  | INC A             | INC<br>R0           | INC<br>R1           | INC<br>R2           | INC<br>R3           | INC<br>R4           | INC<br>R5            | INC<br>R6           | INC<br>R7           |
| 2           | XCH<br>A,<br>@R0     | XCH<br>A,<br>@R1     | MOV<br>PSR,<br>A  | MOV<br>A,<br>#data    | JMP<br>(page<br>1)  | EN<br>II         |      | CLR A             | XCH<br>A,<br>R0     | XCH<br>A,<br>R1     | XCH<br>A,<br>R2     | XCH<br>A,<br>R3     | XCH<br>A,<br>R4     | XCH<br>A,<br>R5      | XCH<br>A,<br>R6     | XCH<br>A,<br>R7     |
| 3           | XCHD<br>A,<br>@R0    | XCHD<br>A,<br>@R1    | JB1               | MOV<br>UMX,<br>A      | CALL<br>(page<br>1) | DIS<br>II        |      | CPL A             | INCL<br>R0          | INCL<br>R1          | INC<br>CURS         |                     | MOV<br>ALO,<br>A    | MOV<br>AL1,<br>A     | MOV<br>A,<br>VPEN   | MOV<br>A,<br>HFEN   |
| 4           | ORL<br>A,<br>@R0     | ORL<br>A,<br>@R1     | MOV<br>A,T        | ORL<br>A,<br>#data    | JMP<br>(page<br>2)  | MOV<br>VCR,<br>A |      | SWAP<br>A         | ORL<br>A,<br>R0     | ORL<br>A,<br>R1     | ORL<br>A,<br>R2     | ORL<br>A,<br>R3     | ORL<br>A,<br>R4     | ORL<br>A,<br>R5      | ORL<br>A,<br>R6     | ORL<br>A,<br>R7     |
| 5           | ANL<br>A,<br>@R0     | ANL<br>A,<br>@R1     | JB2               | ANL<br>A,<br>#data    | CALL<br>(page<br>2) | MOV<br>SCR,<br>A |      | DA A              | ANL<br>A,<br>R0     | ANL<br>A,<br>R1     | ANL<br>A,<br>R2     | ANL<br>A,<br>R3     | ANL<br>A,<br>R4     | ANL<br>A,<br>R5      | ANL<br>A,<br>R6     | ANL.<br>A,<br>R7    |
| M<br>S      | ADD<br>A,<br>@R0     | ADD<br>A,<br>@R1     | MOV<br>T,A        | ORL<br>PORT,<br>#data | JMP<br>(page<br>3)  | STOP<br>T        | JNF1 | RRC A             | ADD<br>A,<br>R0     | ADD<br>A,<br>R1     | ADD<br>A,<br>R2     | ADD<br>A,<br>R3     | ADD<br>A,<br>R4     | ADD<br>A,<br>R5      | ADD<br>A,<br>R6     | ADD<br>A,<br>R7     |
| 5<br>N<br>7 | ADDC<br>A,<br>@R0    | ADDC<br>A,<br>@R1    | JB3               | ANL<br>PORT,<br>#data | CALL<br>(page<br>3) | STRT<br>T        | JF1  | RR A              | ADDC<br>A,<br>R0    | ADDC<br>A,<br>R1    | ADDC<br>A,<br>R2    | ADDC<br>A,<br>R3    | ADDC<br>A,<br>R4    | ADDC<br>A,<br>R5     | ADDC<br>A,<br>R6    | ADDC<br>A,<br>R7    |
| 8           | MOVX<br>@R0,<br>A    | MOVX<br>@R1,<br>A    | MOV<br>MASK,<br>A | RET                   | JMP<br>(page<br>4)  | CLR<br>F0        | JNF0 | MOV<br>TCP,<br>A  | MOVL<br>R0,<br>A    | MOVL<br>R1,<br>A    | MOV<br>HOME,<br>A   | MOV<br>CURS,<br>A   | MOV<br>A,<br>INTR   | MOVX<br>@CURS,<br>A  |                     |                     |
| 9           | MOVX<br>A,<br>@R0    | MOVX<br>A,<br>@R1    | JB4               | RETR                  | CALL<br>(pagə<br>4) | CPL<br>F0        | JF0  | CLR C             | MOVL<br>A,<br>R2    | MOVL<br>A,<br>R1    | MOV<br>A,<br>HOME   | MOV<br>A,<br>CURS   | MOV<br>A,<br>STAT   | MOVX<br>A,<br>@ CURS |                     |                     |
| A           | MOV<br>@R0,<br>A     | MOV<br>@R1,<br>A     | MOV<br>VINT,<br>A | JMPP<br>@A            | JMP<br>(page<br>5)  | CLR<br>F1        | JNXI | CPL C             | MOV<br>R0,<br>A     | MOV<br>R1,<br>A     | MOV<br>R2,<br>A     | MOV<br>R3,<br>A     | MOV<br>R4,<br>A     | MOV<br>R5,<br>A      | MOV<br>R6,<br>A     | MOV<br>R7,<br>A     |
| в           | MOV<br>@R0,<br>#data | MOV<br>@R1,<br>#data | JB5               | MOVP<br>A,<br>@A      | CALL<br>(page<br>5) | CPL<br>F1        | JXI  | MOV<br>@TCP,<br>A | MOV<br>R0,<br>#data | MOV<br>R1,<br>#data | MOV<br>R2,<br>#data | MOV<br>R3,<br>#data | MOV<br>R4,<br>#data | MOV<br>R5,<br>#data  | MOV<br>R6,<br>#data | MOV<br>R7,<br>#data |
| С           | OUT<br>XMTR          | OUT<br>PORT          | MOV<br>HACC,<br>A | SEL<br>RB0            | JMP<br>(page<br>6)  | SEL<br>MB0       | JZ   | MOV<br>A,<br>PSW  | DEC<br>R0           | DEC<br>R1           | DEC<br>R2           | DEC<br>R3           | DEC<br>R4           | DEC<br>R5            | DEC<br>R6           | DEC<br>R7           |
| D           | XRL<br>A,<br>@R0     | XRL<br>A,<br>@R1     | JB6               | XRL<br>A,<br>#data    | CALL<br>(pagə<br>6) | SEL<br>MB1       | JNZ  | MOV<br>PSW,<br>A  | XRL<br>A,<br>RO     | XRL<br>A,<br>R1     | XRL<br>A,<br>R2     | XRL<br>A,<br>R3     | XRL<br>A,<br>R4     | XRL<br>A,<br>R5      | XRL<br>A,<br>R6     | XRL<br>A,<br>R7     |
| E           | IN<br>RCVR           | IN<br>PORT           | MOV<br>A,<br>HACC | SEL<br>RB1            | JMP<br>(page<br>7)  | SEL<br>MB2       | JNC  | RL A              | DJNZ<br>R0          | DJNZ<br>R1          | DJNZ<br>R2          | DJNZ<br>R3          | DJNZ<br>R4          | DJNZ<br>R5           | DJNZ<br>R6          | DJNZ<br>R7          |
| F           | MOV<br>A,<br>@R0     | MOV<br>A,<br>@R1     | JB7               | MOVP3<br>A,<br>@A     | CALL<br>(page<br>7) | SEL<br>MB3       | JC   | RLC A             | MOV<br>A,<br>R0     | MOV<br>A,<br>R1     | MOV<br>A,<br>R2     | MOV<br>A,<br>R3     | MOV<br>A,<br>R4     | MOV<br>A,<br>R5      | MOV<br>A,<br>R6     | MOV<br>A,<br>R7     |

# **Ordering Information**

# ORDER PART NUMBERS

| ROMIess | NS405-A12N<br>NS405-B12N<br>NS405-C12N | NS405-B18N |
|---------|----------------------------------------|------------|
|---------|----------------------------------------|------------|

# Throughput Considerations In NS405 System Planning

The intricate timing relationships inherent in video generation require that a designer have a firm grasp of the fundamentals of NS405 operation in order to achieve his design objectives. Towards this end the key facets of NS405 operation will be examined and examples given.

The NS405 is a complete video controller that reads in video data, processes it and outputs it to a CRT. Given this, one may derive all essential operating parameters from the following two statements:

- 1. You must be able to read in video data faster than you output it.
- 2. Video data accesses are based on the CPU cycle which in turn is based on the crystal or dot clock.

Application of these two statements immediately leads to a limitation on the character cell width as follows:

if f=crystal frequency or dot clock

then (f  $\div$  1)  $\div$  15 or (f  $\div$  1.5)  $\div$  15 = CPU Instruction Execution Clock Frequency

Since there are three video data accesses each CPU Instruction Execution cycle, there are 3 \*  $(f \div 1) \div 15$  or 3 \*  $(f \div 1.5) \div 15$  video data accesses per second.

if w=dot width of character cell then  $f \div w=$  number of character cells being displayed per second.

Statement 1 says that video data accesses/sec  $\geq$  display characters/sec

| for CPU Clock ÷ 1 | for CPU Clock ÷ 1.5 |
|-------------------|---------------------|
| 3*(f÷1)÷15≥f÷w    | 3 * (f÷1.5)÷15≥f÷w  |
| f÷5≥f÷w           | (3 * f)÷22.5≥f÷w    |
| 1⁄₅≥1/w           | 3/22.5≥1/w          |
| w≥5               | w≥7.5               |

So depending on the CPU clock divide factor ( $\div$  1 or  $\div$  1.5) the character cell width must be a minimum as shown.

Cell width also impacts CPU throughput since both the CPU and Video controller vie for video memory access through the DMA controller. The rules of access are simple and straightforward. The Video Controller gets as many of the accesses as it needs with the CPU getting any left over. The maximum access rate as already shown is  $f \div 5$  or  $f \div 7.5$ depending on the CPU clock divide. If the CPU attempts a video memory access when things are very busy it will be put into a wait state and remain frozen until things clear up. Of course, no display characters are necessary when the display is blanked, so during the horizontal and vertical retrace periods the CPU has unlimited access to video memory.

Normally, the CPU doesn't have to wait until horizontal retrace to get into video memory, but exactly how often it can get in during a display line requires analysis of the worst case video requirements.

Since the results can vary dramatically depending on the parameters chosen, two typical cases will be presented.

I. With a dot clock of 18 MHz the display line consists of 80 character cells, 9 dots across. Since the CPU clock divide must be 1.5 the video memory access rate is 18 MHz  $\div$  7.5 = 2.4 MHz.

National Semiconductor Application Brief 14 James Murashige



To display one line requires  $(9 \times 80)/18$  MHz=40 us.

In one line time there are 2.4 MHz×40 us=96 video memory accesses. Of the 96, 80 are required for the characters displayed in the line leaving 16 available for the CPU. This is an average of one every six video memory accesses or once every two CPU instruction cycles. This would be fine since all CPU video memory instructions require two instruction cycles to execute anyway. However, in addition to the DMA controller the video circuits also employ a four level FIFO to insure a smooth data flow. The FIFO is normally kept full at four in which case it stops accessing video data and allows the CPU to have all the accesses. However, the FIFO can drop down quite far before starting to fill up again by taking all of the video memory accesses. The net effect is that instead of being evenly distributed, the accesses available to the CPU are clumped together with long gaps between clumps. Taking the worst case condition of the FIFO being completely empty and having to fill to four by taking the accesses which the CPU could have gotten, the longest gap is  $(4 \times 6) + 5 = 29$  accesses  $\approx 10$ CPU instruction cycles. Generally speaking this tends to happen towards the middle of a line since the FIFO is filled prior to the start of a line and tries to end a line empty. In fact, accesses for video are performed up to the second to the last display character. The FIFO prefetch for the next line is performed shortly after horizontal blanking starts.

II. If the dot clock is now 12 MHz with a display line of 80 character cells 7 dots across the CPU clock divide can be 1.

The video memory access rate is 12 MHz $\div$ 5=2.4 MHz. To do one line requires (7×80)/12 MHz=46.7 us. In one line time there are 2.4 MHz×46.7 us=112 video memory accesses. Of the 112, 32 are now available to the CPU. This averages out to one every 3.5. Figuring the FIFO in, the worst case wait for the CPU becomes (4×3.5)+2.5=16.5 accesses≈6 CPU instruction cycles. A significant improvement over the first example.

In general, to maximize CPU access to video memory one must maximize the average number of "free" accesses during the display time. The number of free accesses as a fraction of the total number available is:

(w-5d)/w Where w=character cell dot width d=CPU divide factor of 1 or 1.5

As can be seen, throughput performance depends entirely on the cell width and CPU clock divide. To maximize performance one would try to choose a large w and a d of 1. Applying the delay imposed by the four level FIFO, the maxi-

mum CPU delay in accessing video memory becomes = (4w+5d)/(w-5d) Memory cycles

# NS405-Series TMP External Interrupt Processing

The TMP External Interrupt (INTR) is a level sampled interrupt input. Specifically this means that the input is sampled once each CPU cycle with interrupts being generated as long as the sampled input is a logic low. INTR shares pin 37 with RE10 and is sampled on each ALE rising edge as shown in the data sheet. If a logic low level is detected, interrupt service will commence if interrupts had been previously enabled with an EN XI instruction. Service consists of finishing up the currently executing instruction, pushing the PC and other pertinent information onto the stack, disabling all interrupts while in service and finally performing a JUMP to location 003. Upon completion of service a RETR would be executed to pop the stack and return to where we left off in the main program.

The exact timing involved may be observed through the example program of *Figure 1* and its instruction execution sequence in *Figure 2*. In *Figure 2* the numbers shown on the falling ALE edges are the program addresses put out by the TMP. As written the program will loop endlessly unless diverted by an external interrupt such as point A in *Figure 2*. Since it just missed the previous rising ALE edge it will not be until point B that the logic low INTR is read in. However, by then the CPU will have started execution of the first byte of the JMP 11 instruction. Since instructions are always finiterrupt service. At this point the next address would have been back at 11 but we now want to service the interrupt and push the stack. Stack pushing or popping takes 2 CPU

National Semiconductor Application Brief 16 James Murashige



cycles so the two address 11's shown following point C are dummies. Finally, we start interrupt service at point D by outputting address 003 and reading in the IN PORT instruction. Since the IN PORT instruction is only 1 byte long but takes 2 CPU cycles to execute, the address "4" at point E is a dummy and isn't really needed until point F when we read in the RETR instruction. Like IN PORT, RETR is a 1 byte instruction that takes 2 CPU cycles to execute. Therefore, the address "5" at point G is redundant. Upon returning from subroutine we immediately push the stack again (point H) since the interrupt is still there. Note that we immediately push the stack and do not execute the JMP at 11. Once more we go through the interrupt service routine but this time the interrupt ends at point I. Since it missed the preceding rising ALE edge where it was still seen as a logic low, we will immediately execute another interrupt service routine as shown. Finally, at point J as we prepare to return from service, INTR will be seen as a logic high and from point K onward execution will proceed normally.

When enabling and disabling interrupts, the rules for when you will and will not service them are predicated on the latest sampled interrupt level and last instruction executed. This is illustrated by the example program of *Figure 3* and instruction execution sequences of *Figure 4*. As shown in *Figure 4a*, the interrupt goes low at point A and will be sampled at the rising ALE of point B. However, since the current executing instruction (DIS XI at location 13) must be completed before starting interrupt service, the interrupt will be



**AB-16** 

locked out. Execution continues unperturbed until the interrupt is re-enabled with an EN XI from location 11, point F. Although the interrupt went logic high at point E it was still sampled as a logic low at point D.

Therefore, after executing the EN XI at location 11, interrupt service will commence as shown. If the interrupt had gone logic high before point D it would have been sampled high and no interrupt service would have been performed. Returning to the missed interrupt at point A, if the interrupt low had come in time to be sampled at point G, the instruction at 12 would have been the last one executed before interrupt service started as demonstrated in *Figure 4b*.

Although describing the external interrupt, all of the service sequences presented may be directly applied to TMP internal interrupts.



AB-16

# TMP Row and Attribute Table Lookup Operation

This note describes in detail the operation of the TMP Attribute Demo Program - TAD. Although a short program, it nicely demonstrates row table lookup operation in the TMP while at the same time putting out a visual display of the various video attributes available in the chip. While this display management approach is much more involved than normal sequential lookup mode, it is necessary when attemping to do fast screen updates or line editing with the TMP.

The hardware environment for which the program was written is the TMP Demo board. Appropriate references to and descriptions of the hardware will be made as necessary. For those who have not seen it, the net function of the program is to put up and manage a single frame of video data. In the top half of the display the same message is repeated 5 times but each time with a different set of attributes. In the lower half of the display are 4 rows representing the 128 possible block graphics patterns. All of the attribute effects displayed are achieved by updating the internal ALO attribute latch at the end of each display row. At the same time a message table lookup is performed in order to obtain the appropriate character string that will work with the new attribute set selected.

The flowchart for the program is shown in *Figure 1*. As you can see, the program essentially consists of initialization and waiting for and servicing video interrupts to manage the screen display. Initialization starts at BEGIN with the Vertical Interrupt Register and Timing Chain being loaded first. The Vertical interrupt is used for end of frame synchronization

National Semiconductor Application Note 354 James Murashige



and is set to activate after the 27th row. The Timing Chain is loaded as follows:

| 40 10101 | · • ·                    |   |     |  |
|----------|--------------------------|---|-----|--|
| TCP 0    | Horizontal Length        | = | 104 |  |
| 1        | Characters/Row           | = | 80  |  |
| 2        | Horizontal Sync Begin    | = | 84  |  |
| 3        | Horizontal Sync End      | = | 100 |  |
| 4        | Character Height         | = | 10  |  |
|          | Extra Scans/Frame        | = | 2   |  |
| 5        | Vertical Length          | = | 27  |  |
| 6        | Vertical Blank           |   | 25  |  |
| 7        | Vertical Sync Begin/End  | = | 7,3 |  |
| 8        | Status Row Begin         |   | 31  |  |
| 9        | Blink Rate/D.C.          | = | F4H |  |
| 10       | Graphics Column Register | = | 30H |  |
| 11       | Graphics Row Register    | = | 36H |  |
| 12       | Underline Size Register  | = | 89H |  |
| 13       | Cursor Size Register     | = | 09H |  |

Given these values, one can ascertain that the display is 80 columns across and 25 rows tall. The character cell height is 10 scan lines and no status line will be displayed. The character underline is the bottom most scan line in a cell and the cursor occupies an entire cell. The partitioning of the block graphics cells is as follows:



AN-354

Following timing chain initialization various system registers are set to configure the chip to operate in its hardware environment. The video memory is a 2kX8 NMC2116 located between addresses 000-7FF. The crystal dot clock is 12 Mhz allowing us to use divide by 1 to generate the CPU clock. Accordingly the SCR is set to 24H (SB8-15 address output only, cell width = 7, divide by 1 for CPU clock, row table lookup operation). RAM Bank 0 is selected and HOME, BEGD, RA/RO are cleared. ENDD and CURS are set to 7FFFH and AL1 is set to FFH (no attributes selected). Video display memory (80×25 char) is then cleared out by storing spaces at all of the memory locations. Along with the spaces, attribute latch 1 is specified to be used. Video is then turned on by setting the VCR to 21H (normal alphanumeric display, internal attribute latch operation, normal video).

Next, the message tables are built up in the video memory. By updating the attribute latch ALO each row, the entire screen display can be constructed from the 7 message rows stored in memory. Each of the message rows consist of 80 consecutive characters and are called up for display by loading the HOME register with the address of the first character in the row. The background characters in each of the rows are the spaces previously stored. Each of the display characters stored use attribute latch AL0 which is updated each row. The first row (0-79) consists entirely of spaces to provide us with a blank display row. The second row (80-159) has the message "tmp does it BETTER!" for normal and double high display. The third row (160-239) contains "ttmmpp ddooeess iitt BBEETTTTEERR!!" for double wide and double size display. Rows 4-7 contain 32 block graphics characters per row for a total of 128 patterns. The 128 characters stored are merely all binary combinations of the low 7 data bits in ascending order. The 32 characters in each row are stored in every other memory location to achieve a blank space between characters. For all of the message rows, data is positioned to give a centered display on the screen.

With initialization accomplished, we set the interrupt mask, re-enable interrupts and wait for a video interrupt.

Video display management is performed by the internal interrupt service routine located at 007 and consists of updating the HOME register and AL0 at the end of each display row. To accomplish this, a row counter (R3) is used as a pointer into the data lookup tables which follow the interrupt service routine. The R3 row counter is incremented on each End of Row interrupt or preset and incremented on a resynching Vertical Interrupt.

Because the next row pointers are pipelined in the video memory controller, an understanding of End of Row and Vertical Interrupt operation is necessary in order to correctly set up the interrupt service routine and lookup tables. In table lookup mode, the Current Row Start Register (CRSR), which is a pointer to the first character address in a row, is automatically reloaded from the HOME register after the display of the last scan line in a row, a few characters into horizontal blanking. The timing of the CRSR reload when operating in sequential lookup mode is the same but in this case the pointer is advanced by the character width of the display row. It is the reloading of CRSR either in sequential or table lookup modes that generates the End of Row interrupt. The duration of the signal is 1/3 CPU cycle making it a one time event each row. The End of Row interrupt register bit is cleared when a reload of HOME, i.e., MOV HOME, A is

executed. A simple example will illustrate the pipelining involved. In Figure 2, at the end of Row 1 (Point A) an EOR interrupt is generated. In preparation for this event HOME should have been loaded with the starting address of ROW 2 since the interrupt is generated when CRSR reloads from HOME. In service of the EOR, the program would load HOME with the starting address of ROW 3 in preparation for the EOR interrupt at Point B. However, notice that we have an entire row time from A to B to do the HOME reload. Finally note that EOR's are generated at the end of all rows except those blanked during vertical blanking. Vertical Interrupt operates with the same timing as End of Row except that it is specified to occur at the end of a particular row designated by the Vertical Interrupt Register. The row that it is specified to occur on must be <= Vertical Length Register (timing chain rows are counted starting from 0). Otherwise, it will never occur since the row counter will never count up that far. Usually Vertical Interrupt is specified to occur on a row blanked during vertical blanking so that it may be used as a frame sync signal.

Returning to TAD, Figure 3 shows the interrupt positioning for all of the rows on the screen including the blanked ones. There are 25 displayed rows and 2 blanked ones in a frame for a total of 27. In addition, there are 2 extra scan lines which may be ignored as far as interrupt operation is concerned. Vertical Interrupt is set to occur at the end of the last row in the frame as shown. Row pointer operation for rows 2 to 24 is pipelined as described in Figure 2. At the end of ROW 24 (point E) the CRSR will be loading the pointer to ROW 25 and the interrupt service will load HOME with the pointer to ROW 1. At the end of ROW 25 (point F) the CRSR will load the pointer to ROW 1 and save it for the next frame. Since no EOR's are generated during vertical blanking, CRSR will remain static until ROW 1. At this point, it doesn't matter what the interrupt service loads into HOME and AL0 since the Vertical Interrupt at ROW 27 will reset the row counter and perform a new lookup for HOME and AL0. A Vertical Interrupt will not do a CRSR load, thus the pointer to ROW 1 will be preserved. At Vertical Interrupt, the row counter will be reset to 0 and we will want to do a pointer lookup for ROW 2 in preparation for the CRSR load at the end of ROW 1 (point A). Correspondingly, the row pointer lookup tables are organized 2 to 25, 1. Since the attribute latches aren't pipelined, the AL0 lookup table is arranged 1 to 25 since the new attribute set will be needed immediately for the display of the next row.





TL/C/5729-2



7-48

|                    |                | _         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                             |
|--------------------|----------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TMP                | Attribute      | e Demo    | Program (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Continued)                                                                                                                                                                                                                                  |
| 44 00              | 15 B3          |           | MOVP A, @A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ;LOAD HOME                                                                                                                                                                                                                                  |
| 45 00.             |                |           | MOV HACC, A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | W . CEM NOVE LOW ODDED DUMP                                                                                                                                                                                                                 |
| 40 00.             | L7 2336        |           | MOV A, #HUMLU                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | W GET HOME LOW ORDER BITE                                                                                                                                                                                                                   |
| 47 00.             | L9 0D          |           | NOUP A @A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                             |
| 40 00.             | IR OA          |           | MOVE A, WA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | JOAD HOVE                                                                                                                                                                                                                                   |
| 49 00.<br>50 00    | LD OA<br>10 03 |           | MOV HUME, A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | LOAD HOME                                                                                                                                                                                                                                   |
| 51                 | 10 30          | FORM      | MB1M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                             |
| 52                 |                | • P OI UN |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                             |
|                    |                |           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                             |
| 54                 |                | ,         | IGH ORDER BYTE<br>BYTE 0<br>BYTE 1<br>LINE5<br>BYTE 0<br>BYTE 4<br>BYTE 0<br>BYTE 4<br>BYTE 0<br>BYTE 0<br>BYTE 1<br>BYTE 0<br>BYTE 0 |                                                                                                                                                                                                                                             |
| 55 00              | LD 00          | HOMHIG:   | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | :ROW 2                                                                                                                                                                                                                                      |
| 56 003             | LE 00          |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ROW 3                                                                                                                                                                                                                                       |
| 57 00              | LF 00          |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ROW 4                                                                                                                                                                                                                                       |
| 58 003             | 20 00          |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ROW 5                                                                                                                                                                                                                                       |
| 59 003             | 21 00          |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ROW 6                                                                                                                                                                                                                                       |
| 60 00              | 22 00          |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ;ROW 7                                                                                                                                                                                                                                      |
| 61 003             | 23 00          |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ;ROW 8                                                                                                                                                                                                                                      |
| 62 003             | 24 00          |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ;ROW 9                                                                                                                                                                                                                                      |
| 63 003             | 25 00          |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ;ROW 10                                                                                                                                                                                                                                     |
| 64 00              | 26 00 32       |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ;ROW 11                                                                                                                                                                                                                                     |
| 65 003             | 27 00          |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ;ROW 12                                                                                                                                                                                                                                     |
| 66 003             | 28 00 83       |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ;ROW 13                                                                                                                                                                                                                                     |
| 67 003             | 29 00          |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ;ROW 14                                                                                                                                                                                                                                     |
| 68 003             | 2A 00 AS       |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ;ROW 15                                                                                                                                                                                                                                     |
| 69 002             | 2B 00          |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ;ROW 16                                                                                                                                                                                                                                     |
| 70 003             | SC 00          |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ;ROW 17                                                                                                                                                                                                                                     |
| 71 00              | 2D 00          |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ;ROW 18                                                                                                                                                                                                                                     |
| 72 00              | 2E 01          |           | .BYTE H(LINE5)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ) ;ROW 19                                                                                                                                                                                                                                   |
| 73 00              | 2F 00          |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ;ROW 20                                                                                                                                                                                                                                     |
| 74 00              | 30 01          |           | .BYTE H(LINE6)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ) ;ROW 21                                                                                                                                                                                                                                   |
| 75 00              | 51 00          |           | .BITE U                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ;ROW 22                                                                                                                                                                                                                                     |
| 76 00              | 52 01          |           | BITE H(LINEY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ) ;RUW 23                                                                                                                                                                                                                                   |
| 77 00              | 33 00          |           | BITE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RUW 24                                                                                                                                                                                                                                      |
| 70 00              | 34 00          |           | DILL U                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ,ROW 20                                                                                                                                                                                                                                     |
| 80 00              | 36 00          |           | FORM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ,                                                                                                                                                                                                                                           |
| 81                 | 50 00          |           | • FOIM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                             |
| 82                 |                | HOME LO   | W ORDER BYTE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | LOOKUP TABLE                                                                                                                                                                                                                                |
|                    |                |           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                             |
| 84 003             | 36 00          | HOMLOW:   | BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | <pre>;ROW 2 BLANK<br/>) ;ROW 3 NORMAL<br/>;ROW 4 BLANK<br/>) ;ROW 5 DOUBLE WIDE<br/>;ROW 6 BLANK<br/>) ;ROW 7 DOUBLE HIGH<br/>;ROW 8 DOUBLE HIGH<br/>;ROW 9 BLANK<br/>) ;ROW 10 DOUBLE SIZE<br/>;ROW 11 DOUBLE SIZE<br/>;ROW 12 BLANK</pre> |
| 85 003             | 37 50          |           | .BYTE L(LINE2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ) :ROW 3 NORMAL                                                                                                                                                                                                                             |
| 86 003             | 38 00          |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ROW 4 BLANK                                                                                                                                                                                                                                 |
| 87 003             | 39 AO          |           | .BYTE L(LINE3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ) ROW 5 DOUBLE WIDE                                                                                                                                                                                                                         |
| 88 003             | 3A 00          |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ROW 6 BLANK                                                                                                                                                                                                                                 |
| 89 003             | 3B 50          |           | .BYTE L(LINE2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ) ROW 7 DOUBLE HIGH                                                                                                                                                                                                                         |
| 90 00              | 3C 50          |           | .BYTE L(LINE2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ) ;ROW 8 DOUBLE HIGH                                                                                                                                                                                                                        |
| 91 003             | 3D 00          |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ;ROW 9 BLANK                                                                                                                                                                                                                                |
| 92 003             | 3E AO          |           | .BYTE L(LINE3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ) ;ROW 10 DOUBLE SIZE                                                                                                                                                                                                                       |
| 93 003             | 3F AO          |           | .BYTE L(LINE3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ) ;ROW 11 DOUBLE SIZE                                                                                                                                                                                                                       |
| 94 004             | <b>1</b> 0 00  |           | .BYTE O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ;ROW 12 BLANK                                                                                                                                                                                                                               |
| 95 004             | 41 AO          |           | .BYTE L(LINE3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ) ;ROW 13 DOUBLE SIZE                                                                                                                                                                                                                       |
| 96 004             |                |           | .BYTE L(LINE3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                             |
| 97 004             |                |           | .BYTE L(LINEL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                             |
| 98 004             |                |           | .BYTE L(LINE1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                             |
| 99 004             |                |           | .BYTE L(LINE4)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                             |
| 100 004            |                |           | .BYTE L(LINE1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                             |
| 101 004            |                |           | .BYTE L(LINE5)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                             |
| 102 004            |                |           | .BYTE L(LINE1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                             |
| 103 004            |                |           | .BYTE L(LINE6)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                             |
| 104 004            |                |           | .BYTE L(LINE)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                             |
| 105 004            |                |           | .BYTE L(LINE7)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                             |
| 106 004<br>107 004 |                |           | .BYTE L(LINEL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                             |
| 107 004            |                |           | .BYTE L(LINEL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | , ,                                                                                                                                                                                                                                         |
| 200 004            |                |           | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | , , , , , , , , , , , , , , , , , , ,                                                                                                                                                                                                       |

| 09           | te Demo Program      | . ,                                 |
|--------------|----------------------|-------------------------------------|
| 10           |                      |                                     |
| 11           | ATTRIBUTE LATCH O LO | OOKUP TABLE                         |
| 12           | •                    |                                     |
| 13 004F FF   | ATTO: .BYTE OFF      | ;ROW 1                              |
| 14 0050 FF   | .BYTE OFF            | ROW 2                               |
| 15 0051 FF   | .BYTE OFF            | :ROW 3                              |
| 16 0052 FF   | .BYTE OFF            | :ROW 4                              |
| 17 0053 EF   | .BYTE OEF            | :ROW 5                              |
| 18 0054 FF   | .BYTE OFF            | :ROW 6                              |
| 19 0055 F7   | .BYTE OF7            | :ROW 7                              |
| 20 0056 B7   | .BYTE OB7            | :ROW 8                              |
| 21 0057 FF   | .BYTE OFF            | :ROW 9                              |
| 22 0058 E7   | .BYTE OE7            | :ROW 10                             |
| 23 0059 A7   | .BYTE OA7            | :ROW 11                             |
| 24 005A FF   | .BYTE OFF            | :ROW 12                             |
| 25 005B E2   | .BYTE OE2            | :ROW 13                             |
| 26 005C 82   | .BYTE 082            | :ROW 14                             |
| 27 005D FF   | .BYTE OFF            | :ROW 15                             |
| 28 005E FF   | .BYTE OFF            | :ROW 16                             |
| 29 005F 7F   | .BYTE O7F            | :ROW 17                             |
| 30 0060 FF   | .BYTE OFF            | :ROW 18                             |
| 31 0061 7F   | .BYTE 07F            | :ROW 19                             |
| 32 0062 FF   | .BYTE OFF            | :ROW 20                             |
| 33 0063 7F   | .BYTE 07F            | :ROW 21                             |
| 34 0064 FF   | .BYTE OFF            | :ROW 22                             |
| 35 0065 7F   | .BYTE 07F            | :ROW 23                             |
| 36 0066 FF   | .BYTE OFF            | :ROW 24                             |
| 37 0067 FF   | .BYTE OFF            | :ROW 25                             |
| 38           | .FORM                |                                     |
| 39           |                      |                                     |
| 40           | START OF INITIALIZI  | NG CODE                             |
| 41           |                      |                                     |
| 42 0068 15   | BEGIN; DIS XI        | ;INTERRUPTS OFF FOR NOW             |
| 43 0069 35   | DIS II               |                                     |
| 44 006A 65   | STOP T               |                                     |
| 45 006B 231A | MOV A, #26           |                                     |
| 46 006D A2   | MOV VINT, A          |                                     |
| 47 006E 27   | CLR A                | ;SET UP TIMING CHAIN FOR DEMO BOARD |
| 48 006F 87   | MOV TCP, A           |                                     |
| 49 0070 2367 | MOV A, #103          | ;HORIZONTAL LENGTH                  |
| 50 0072 B7   | MOV @TCP, A          |                                     |
| 51 0073 234F | MOV A, #79           | ;CHARACTERS/ROW                     |
| 52 0075 B7   | MOV @TCP, A          |                                     |
| 53 0076 2353 | MOV A, #83           | ;HORIZONTAL SYNC BEGIN              |
| 54 0078 B7   | MOV @TCP, A          |                                     |
| 55 0079 2363 | MOV A, #99           | ;HORIZONTAL SYNC END                |
| 56 007B B7   | MOV @TCP, A          |                                     |
| 57 007C 2391 | MOV A, #091          | ;CHARACTER HEIGHT/EXTRA SCANS       |
| 58 007E B7   | MOV @TCP, A          |                                     |
| 59 007F 231A | MOV A, #26           | ;VERTICAL LENGTH                    |
| 60 0081 B7   | MOV @TCP, A          |                                     |
| 61 0082 2318 | MOV A, #24           | ;VERTICAL BLANK                     |
| 62 0084 B7   | MOV @TCP, A          |                                     |
| 63 0085 2362 | MOV A, #062          | ;VERTICAL SYNC BEGIN/END            |
| 64 0087 B7   | MOV @TCP, A          |                                     |
| 65 0088 231E | MOV A, #30           | ;STATUS ROW BEGIN                   |
| 66 008A B7   | MOV @TCP, A          |                                     |
| 67 008B 23F4 | MOV A, #OF4          | BLINK RATE                          |
| 68 008D B7   | MOV @TCP, A          |                                     |
| 69 008E 2330 | MOV A, #030          | GRAPHICS COLUMN REGISTER            |
| 70 0090 B7   | MOV @TCP, A          |                                     |
| 71 0091 2336 | MOV A, #036          | GRAPHICS ROW REGISTER               |
| 72 0093 B7   | MOV @TCP, A          |                                     |
|              |                      |                                     |

7-50

# AN-354

| TMD Attribu                                                | te Demo Program (Con                                                        | timesed                                                                                |
|------------------------------------------------------------|-----------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
|                                                            |                                                                             | tinued)                                                                                |
| 174 0096 B7                                                | MOV @TCP, A<br>MOV A, #009<br>MOV @TCP, A                                   |                                                                                        |
| 175 0097 2309                                              | MOV A, #009                                                                 | ;CURSOR SIZE REGISTER                                                                  |
| 176 0099 B7                                                | MOV @TCP, A                                                                 |                                                                                        |
| 177                                                        |                                                                             |                                                                                        |
| 178                                                        |                                                                             |                                                                                        |
| 179                                                        | .FORM                                                                       |                                                                                        |
| 180 009A 2324                                              |                                                                             | SET SYSTEM CONTROL REGISTER                                                            |
|                                                            | NOV A, TOZT                                                                 | ;8 BI,7 DOTS, DIVIDE 1, TABLE LOOKUP                                                   |
| 181 009C 55                                                | MUV SCR, A                                                                  | 3 BI,7 DUIS, DIVIDE I, IABLE BOOKUP                                                    |
| 182                                                        | _                                                                           |                                                                                        |
| 183 009D C3                                                | SEL RBO                                                                     | ;SELECT RAM BANK O                                                                     |
| 184 009E 27                                                | CLR A                                                                       | ;SET RAM POINTERS                                                                      |
| 185 009F C2                                                | MOV HACC, A                                                                 |                                                                                        |
| 186 00A0 8A                                                | SEL RBO<br>CLR A<br>MOV HACC, A<br>MOV HOME, A<br>MOV BEGD, A<br>MOVL RO, A |                                                                                        |
| 187 00A1 0D                                                | MOV BEGD. A                                                                 |                                                                                        |
| 188 0042 88                                                | MOVI BO A                                                                   | CLEAR MEMORY POINTER                                                                   |
| 189                                                        | MOVE NO, A                                                                  | , CLEAR MEMORY I CINIER                                                                |
|                                                            | NOT A #08P                                                                  |                                                                                        |
| 190 00A3 237F<br>191 00A5 C2                               | MOV A, #U/F                                                                 |                                                                                        |
| 191 00A5 C2<br>192 00A6 23FF<br>193 00A8 0C<br>194 00A9 8B | MOV A, #07F<br>MOV HACC, A                                                  |                                                                                        |
| 192 00A6 23FF                                              | MOV A. #OFF                                                                 |                                                                                        |
| 193 OOA8 OC                                                | MOV ENDD, A                                                                 |                                                                                        |
| 194 OOA9 8B                                                | MOV ENDD, A<br>MOV CURS, A                                                  |                                                                                        |
| 195 00AA 3D                                                | MOV ALL. A                                                                  | ;NO ATTRIBUTES FOR LATCH 1                                                             |
| 196                                                        |                                                                             | ,                                                                                      |
| 197                                                        | CLEAR OUT MEMORY                                                            |                                                                                        |
| 198                                                        | ,ODBAR OOI MEMORI                                                           |                                                                                        |
| 190                                                        | NON DE MOE                                                                  |                                                                                        |
| 199 OOAB BD19                                              | MOV R5, #25                                                                 | ;DU 25 ROWS                                                                            |
| 200 00AD BA50<br>201 00AF 23A0                             | MOV R2, #80                                                                 | :DO 25 ROWS<br>;DO 80 CHARACTERS PER ROW<br>;INITIALIZE FOR A SPACE, ATTRIBUTE LATCH 1 |
| 201 00AF 23A0                                              | MOV A, #OAO                                                                 | ;INITIALIZE FOR A SPACE, ATTRIBUTE LATCH 1                                             |
| 202                                                        |                                                                             |                                                                                        |
| 203 00B1 80                                                | LOOP: MOVX @RO, A                                                           | STORE A CHARACTER                                                                      |
| 204 0082 38                                                | INCL RO                                                                     | INCREMENT POINTER                                                                      |
| 205 00B3 EAB1                                              | DINZ RO LOOP                                                                | TEST IF BOW DONE                                                                       |
| 206 OOB5 BASS                                              | INCL RO<br>DJNZ R2, LOOP<br>MOV R2, #80                                     | , IDSI II NON DOND                                                                     |
| 200 00D5 BASO                                              | DING DE LOOD                                                                | ;TEST IF SCREEN DONE                                                                   |
| 207 00B7 EDB1                                              | DJNZ R5, LOOP                                                               | TEST IF SCREEN DONE                                                                    |
| 208                                                        |                                                                             |                                                                                        |
| 209 00B9 2321                                              | MOV A, #021                                                                 | ;SET VCR FOR INTERNAL ATTRIBUTES<br>:INTERNAL CHARACTER GENERATOR                      |
| 210 00BB 45                                                | MOV VCR, A                                                                  | :INTERNAL CHARACTER GENERATOR                                                          |
| 211                                                        |                                                                             |                                                                                        |
| 212                                                        |                                                                             |                                                                                        |
|                                                            | FIRST LINE ARE ALL BLAN                                                     | KS, SECOND LINE HAS SINGLE SPACING MESSAGE                                             |
| 214 00BC 2300                                              |                                                                             | +30) ;SET RO POINTER TO FIRST LINE                                                     |
| 214 00BC 2300<br>215 00BE C2                               |                                                                             | 100, JEI NO IOIMIEN IO FINSI EINE                                                      |
|                                                            |                                                                             | 1.70)                                                                                  |
| 216 OOBF 236E                                              |                                                                             | +30)                                                                                   |
| 217 00C1 88<br>218 00C2 BAE0<br>219 00C4 BB13              | MOVL RO, A                                                                  |                                                                                        |
| 218 00C2 BAE0                                              | MOV R2, #L(MSG1                                                             | ) ;SET R2 TO MESSAGE #1                                                                |
| 219 00C4 BB13                                              | MOV R3, #19                                                                 | SET R3 TO MESSAGE LENGTH                                                               |
| 220 00C6 FA                                                | DISP1: MOV A, R2                                                            |                                                                                        |
| 221 00C7 B3                                                | MOV A, @A                                                                   | DISPLAY NORMAL MESSAGE                                                                 |
| 222 0008 80                                                | MOVX @RO,A                                                                  | ,                                                                                      |
| 223 0009 38                                                | INCL RO                                                                     |                                                                                        |
| 224 00CA 1A                                                | INC R2                                                                      |                                                                                        |
|                                                            |                                                                             |                                                                                        |
| 225 00CB EBC6                                              | DJNZ R3, DISP1                                                              |                                                                                        |
| 226                                                        | .FORM                                                                       |                                                                                        |
| 227                                                        | THIRD LINE HAS DOUBLE W                                                     |                                                                                        |
| 228 00CD 98                                                | MOVL A, RO                                                                  | ;SET RO POINTER                                                                        |
| 229 00CE 0334                                              | ADD A, #(31 + 2                                                             | 21) ;LINES3 + 21                                                                       |
| 230 00D0 88                                                | MOVL RO, A                                                                  |                                                                                        |
| 231 00D1 BAE0                                              | MOV R2, #L(MSG1                                                             |                                                                                        |
| 232 00D3 BB13                                              |                                                                             | ,                                                                                      |
|                                                            | MOV R3, #19                                                                 |                                                                                        |
| 233 00D5 FA                                                | DISP2: MOV A, R2                                                            | STOPLAN BOURTE WITH                                                                    |
| 234 00D6 B3                                                | •                                                                           | ;DISPLAY DOUBLE WIDE                                                                   |
| 235 00D7 80                                                | MOVX @RO, A                                                                 |                                                                                        |
| 236 00D8 38                                                | INCL RO                                                                     |                                                                                        |
| 237 00D9 80                                                | MOVX @RO, A                                                                 |                                                                                        |
| 238 00DA 38                                                | INCL RO                                                                     |                                                                                        |
| · - · · · · · · · · · · · · · · · · · ·                    |                                                                             |                                                                                        |

#### TMP Attribute Demo Program (Continued) 239 00DB 1A INC R2 240 00DC EBD5 DJNZ R3, DISP2 241 00DE 04F3 JMP FOURTH 242 243 00E0 74 MSQ1: .BYTE 'tmp does it BETTER!' 244 245:FOURTH LINE STARTS GRAPHICS CHARACTERS DISPLAY246 00F3 98FOURTH: MOVL A, RO 247 00F4 031D ADD A, #(21 + 8);LINE4 + 8 248 00F6 88 MOVL RO, A 249 00F7 BB04 250 00F9 BA20 251 00FB 2300 252 00FD 2400 MOV A, #000 ATTRIBUTE LATCH O SELECTED JMP BLOOP 253 254 0100 . = 0100 255 256 0100 80 BLOOP: MOVX @RO, A ;STORE CHARACTER 257 0101 38 INCL RO 258 0102 38 INCL RO 259 0103 17 INC A 260 0104 EA00 DJNZ R2, BLOOP 261 MOV R2, #32 MOV R4, A ;INITIALIZE FOR NEW ROW 262 0106 BA20 263 0108 AC ;TEMPORARY SAVE A MOVL A, RO ADD A, #(8+8) ;POINT TO NEXT LINE 264 0109 98 265 010A 0310 MOVL RO, A 266 0100 88 267 OlOD FC MOV A, R4 RESTORE A DJNZ R3, BLOOP ;CONTINUE IF NOT THROUGH 268 010E EB00 270 ;REENABLE INTERNAL INTERRUPTS AND MASK OFF UNUSED ONES 271 0110 2303 MOV A, #03 272 0112 82 MOV MASK, A 273 0113 25 THE CONSTRUCTION 274 0114 2414 PAU: JMP PAU WAIT FOR A VIDEO INTERRUPT 275 END ATTO 004F BEGIN 0068 BLOOP 0100 DISP2 00D5 EOR 000C EXI 0003 \* DISP1 0006 FOURTH OOF3 HOMHIGOOLDHOMLOWOO36INIOO07\*LINE2OO50LINE3OOA0LINE4OOF0LINE3OIA0LINE4OOF0 LINE1 0007 \* 0000 LINE5 0140 0190 LINE6 LOOP LINE7 01E0 00B1 MSG1 00E0 0000 \* PAU 0114 RESET NO ERROR LINES 272 ROM BYTES USED SOURCE CHECKSUM = CF60 OBJECT CHECKSUM=0576 INPUT FILE A: TAD. MAC LISTING FILE A: TAD. PRN OBJECT FILE A: TAD. LM

# TMP - Dynamic RAM Interfacing

TMPs Interface easily and directly to dynamic RAMs as illustrated in the basic TMP system schematic of *Figure 1*. In addition to providing the necessary Read/Write cycle control, the TMP will also automatically refresh the memories through the video controller, further easing interface requirements.

The circuitry to the right of the TMP provides program memory interfacing and I/O support while to the left lie the dynamic video RAM circuits. The memory width shown here is 8 bits although 16 bits can easily be accommodated. Using the 64K  $\times$  1 dynamic RAMs shown the entire video memory space is filled with RAM. However, by using a slightly modified addressing configuration smaller memroy chips could be substituted.

The requisite dynamic RAM control signals  $\overrightarrow{RAS}$ ,  $\overrightarrow{CAS}$  and  $\overrightarrow{WE}$  are generated directly from the system bus control signals RAM ALE,  $\overrightarrow{RAM}$   $\overrightarrow{RD}$  and  $\overrightarrow{RAM}$   $\overrightarrow{WR}$ . RAM ALE is used directly as  $\overrightarrow{RAS}$  while  $\overrightarrow{RAM}$   $\overrightarrow{WR}$  serves as  $\overrightarrow{WE}$ .  $\overrightarrow{CAS}$  is the logical AND of  $\overrightarrow{RAM}$   $\overrightarrow{RD}$  and  $\overrightarrow{RAM}$   $\overrightarrow{WR}$ . The 16 system bus bits are multiplexed down to the 8 bit RAM address vector by the two 74LS157's under the control of the RAM ALE. As configured, the row and column addresses strobed in are SB0-7 and SB8-15 respectively.

With the configuration shown, the pertinent TMP Read and Write cycle timing parameters for *Figure 2* are listed in Table 1. Going through the table one sees that the TMP easily interfaces to 150 ns access RAMs and will routinely work with 200 ns RAMs. The four parameters which may be a tight squeeze for 200 ns RAMs are:

- 1. t<sub>RAC</sub>— Access Time from RAS is max 150 ns, typ 220 ns. This is a basic access time requirement which necessitates fast parts.
- 2. t<sub>RAH</sub>— Row Address Hold Time is min 10 ns, typ 15 ns. This parameter is entirely dependent on the switching speed of the 74LS157.
- 3. t<sub>RCD</sub>— RAS to CAS Delay Time is min 10 ns, typ 50 ns. This parameter isn't too critical since most dynamic RAMs internally gate the CAS signal should it come along too early.
- t<sub>RP</sub>— RAS Precharge Time is min 100 ns, typ 135 ns. Since RAS is actually the RAM ALE signal t<sub>RP</sub> is the high time of RAM ALE.

However, rather than getting faster RAMs one could also meet spec by running the TMP CPU slower, thereby stretching out the allowable access time.

Since the TMP video controller will regularly and automatically access video memory in order to obtain characters for display, one may have dynamic RAM refreshing performed automatically by making sure that the required number of consecutive address locations (ROW Addresses) are accessed in the alloted time. Typically this is 128 ROW addresses in 2 ms.

For example, in a typical system we may have an 80 column by 25 row display with each row consisting of 10 scan lines. Each scan line has a period of 60.67 us. The vertical blank National Semiconductor Application Note 355 James Murashige



AN-35

period consists of 25 scan lines for a total duration of 1.52 ms. Assuming sequential rather than table lookup operation, 80 consecutive character addresses are accessed each scan line and a 160 consecutive character addresses are accessed every 2 rows; more than enough to refresh all of the  $\overline{\text{RAS}}$  rows. Of course one must be sure that the memory addresses of any two consecutive rows encompass all 128 possible  $\overline{\text{RAS}}$  addresses. In the middle of the screen the worst case refresh period is 11 scan lines (.667 ms), since to do 160 consecutive addresses requires one complete row plus the first scan line of the next row. At the bottom of the screen the refresh period must also include the vertical blank time since no video characters are accessed then. In this case refresh stretches out to a worst case 2.184 ms.

Although in this example we exceeded the 2 ms refresh period, there are a number of things that we could do to get things back into spec. For example, we could cut down on vertical blank time, use memory chips with longer refresh periods, or have the CPU refresh video memory during vertical retrace. Taking the case of using different memory chips, another popular refreshing arrangement is 256 row addresses in 4 ms. In the middle of the screen this gives us a worst case period of 10 + 10 + 10 + 1 scan lines or  $31 \times 60.67$  us = 1.88 ms. Adding in the vertical blanking period the absolute worst case refresh delay is 1.88 + 1.52 = 3.4 ms. Of course in this arrangement, making sure that any four consecutive rows encompass all 256 RAS addresses is much more difficult.

When operating in pixel mode meeting refresh requirements isn't as difficult since each scan line will access a different set of consecutive RAM addresses.

Returning to the circuit of *Figure 1*, we have assumed that SB0–7 are multiplexed address/data while SB8-15 output addresses only. Since the RAM addresses are latched in 8 bits at a time there is no need for a separate latch for SB0–7 since all 8 bits are clocked in on the falling ALE edge. However, when operating with smaller 8K or 16K RAMs where only 7 bits are clocked in at a time, latching arrangements for SB7 must be made. An example of this is shown in *Figure 3* where bits SB0–7 are all latched by the 74LS373.

Normally I/O registers, as well as other memory banks, will also be memory mapped into the 64K video RAM space. In order to do this some sort of chip enabling scheme must be worked out since the dynamic RAMs have no direct enable control. One possibility is shown in *Figure 4* where the RAM bank CAS and WE are disabled unless selected by the 74LS138 decoder. In this way the RAM output drivers will remain TRI-STATE® and no data will be written unless the bank is selected. However, memory refreshing as controlled by RAS will still be performed on each RAM bank.

By expanding on these basic examples a memory configuration for the TMP utilizing dynamic memories may be quickly and easily worked out.

| Symbol           | Parameter                                                    | Min | Тур | Max | Units |
|------------------|--------------------------------------------------------------|-----|-----|-----|-------|
| t <sub>AR</sub>  | Column Address Hold Time Referenced to RAS                   | 250 | 280 |     | ns    |
| tASC             | Column Address Set Up Time-Dependent on Switching of 74LS157 | 25  | 35  |     | ns    |
| t <sub>ASR</sub> | Row Address Set Up Time                                      | 20  | 90  |     | ns    |
| tCAC             | Access Time from CAS                                         |     | 180 | 140 | ns    |
| t <sub>CAH</sub> | Column Address Hold Time                                     | 140 | 250 |     | ns    |
| tCAS             | CAS Pulse Width                                              | 140 | 160 |     | ns    |
| t <sub>CP</sub>  | CAS Precharge Time                                           | 140 | 166 |     | ns    |
| tCRP             | CAS to RAS Precharge Time                                    | 100 | 136 |     | ns    |
| t <sub>CSH</sub> | CAS Hold Time                                                | 250 | 280 |     | ns    |
| t <sub>CWL</sub> | Write Command to CAS Lead Time                               | 140 | 160 |     | ns    |
| t <sub>DH</sub>  | Data In Hold Time                                            | 160 | 175 |     | ns    |
| t <sub>DHR</sub> | Data In Hold Time Referenced to RAS                          | 180 | 310 |     | ns    |
| t <sub>DS</sub>  | Data In Set Up Time                                          | 10  | 50  |     | ns    |
| t <sub>OFF</sub> | Output Buffer Turn Off Delay                                 | 0   |     | 60  | ns    |
| t <sub>RAC</sub> | Access Time from RAS                                         |     | 220 | 150 | ns    |
| t <sub>RAH</sub> | Row Address Hold Time-Dependent on Switching of 74LS157      | 10  | 15  |     | ns    |
| t <sub>RAS</sub> | RAS Pulse Width                                              | 250 | 280 |     | ns    |
| t <sub>RC</sub>  | Random Read/Write Cycle Time                                 | 416 |     |     | ns    |
| t <sub>RCD</sub> | RAS to CAS Delay Time                                        | 10  | 50  |     | ns    |
| t <sub>RCH</sub> | Read Command Hold Time                                       | 100 | 175 |     | ns    |
| t <sub>RCS</sub> | Read Command Set Up Time                                     | 100 | 175 |     | ns    |
| t <sub>RP</sub>  | RAS Precharge Time                                           | 100 | 135 |     | ns    |
| t <sub>RRH</sub> | Read Command Hold Time Referenced to RAS                     | 100 | 175 |     | ns    |
| t <sub>RSH</sub> | RAS Hold Time                                                | 140 | 160 |     | ns    |
| tRWL             | Write Command to RAS Lead Time                               | 140 | 150 |     | ns    |
| twch             | Write Command Hold Time                                      | 140 | 150 |     | ns    |
| twcR             | Write Command Hold Time Referenced to RAS                    | 160 | 275 |     | ns    |
| twcs             | Write Command Set Up Time-Dependent on Delay of 74LS08       | 5   | 11  |     | ns    |
| twp              | Write Command Pulse Width                                    | 140 | 150 |     | ns    |



7-55



TL/C/5732-4







FIGURE 4. Chip Enabling Dynamic RAMs

# TMP External Character Generation

Built into the TMP video circuitry is the ability to access an external character generator to display custom FONT sets. In addition to the flexibility afforded by user selectable FONTs, by going "external" the number of different character patterns directly addressable is virtually limitless. On the other hand the disadvantages of going external are the additional hardware necessary to control data routing and the general need to use faster memories.

Figure 1 shows a minimum configuration with which to do external character generation. In the TMP, external character generation is selected through Video Control Register bits 6, 7 and is a cross between normal alphanumeric and pixel graphics display modes. Like normal alphanumeric mode the TMP sequences through the video memory address space based upon the screen format specification. But instead of routing the data through the internal character generator, it is treated as pixel data and directly inserted into the video attributes are fully operational except for double height and block graphics.

Operation of the circuit shown is straight forward and follows a pipe-line approach. On a video data read the display memory address is output onto the system bus with the 8 low order bits being latched by the 74LS373. On the RAM RD signal the 2116 display RAM ouputs a data character onto the pipeline bus which is used to address the MM52116 character generator which in turn deposits the required pixel data onto the system bus so that it may be read in. The 2116 determines which character is to be looked up in the 52116 while the 74LS163 tells the character generator which row in the character we wish to look at. The 74LS163 is a counter which is appropriately clocked by the horizontal sync pulse so that we will advance each scan line to point to the next row in the character FONT. At the end of each screen row the counter must be cleared in preparation for the display of a new row. This is the function of the Scan Count Clear signal which is available as a multiplexed output on the RE11 pin. It is a low going signal which pulses for 1 scan line time during the last scan line in a screen ROW. Its timing is shown in Figure 2. Note that since the 74LS163 is a fully synchronous counter the clear input will not be accepted until the very last H-Sync clock pulse in the screen row. Because of the necessity to not clear the counter before all pixel data is brought in, nor to delay clocking lest the Scan Count Clear pulse be missed, the starting H-Sync clock edge must be postioned close to the start of horizontal blanking.

Continuing with the read operation, we see that video RAM is only accessed if SB15 is low, i.e., the lower 32K. Note that the 52116 used here contains 128 characters in a 5  $\times$  7 FONT. Consequently, it has 5 data output lines connected

## National Semiconductor Application Note 367 James Murashige



to the system bus. The other three "dummy" lines shown connected are actually output bits which are always 0 by default, thus giving us blank spaces. There are two reasons why the character bits start on SB1. The first is that since everything brought in is considered pixel data, spaces between characters must be externally inserted. The second is that the video controller always brings in 8 bits even though the cell width can be defined to be 9 or 10. In these instances the 9th and 10th bits repeat what was encoded into the SB0 bit. As a result external characters can practically be at most 7 dots wide although the cells can be up to 8, 9, or 10 dots wide. Cell and/or character heights can be up to 16 lines tall as specified by the Character Scan Height Register.

On a video memory write, data is routed through the 81LS95, onto the pipe-line bus and into the 2116. Writing into the 2116 is controlled by RAM WR as shown. Ordinarily the MSB data bit is used for internal attribute latch selection and could be directly connected to the SB7 line if character cells were specified to at most be 7 dots wide. Otherwise SB7 will be needed for pixel generation as shown in Figure 1, thereby rendering internal attribute latch selection useless. In this case both internal attribute latches would have to be loaded with the same values. As shown here, 7 video RAM data bits are used to address the 128 possible characters in the 52116. If a larger character generator were available, additional data bits could be used to select from a larger character set. Since the TMP features a 16-bit multiplexed address/data bus, by using all 16 available data bits we could address 65,536 different character patterns

With the video data pipe-lined as shown, very fast memory circuits are required for external character generation. With a 12 MHz CPU clock, character pixel data must be available within a max of 220ns (typ. 300ns) after an address goes out. To accomplish this the character generator will typically have to be bipolar and the video RAM fast MOS. However, if faster memories are a problem, access times may be stretched out by slowing down the CPU clock since video RAM cycling is based on the CPU clock. For instance with a CPU clock of 8 MHz, access time stretches out to 385 ns max, 500 ns typ. If using the divide by 1.5 factor on the crystal to obtain the slower CPU clock, remember that due to system constraints the character cell MUST BE AT LEAST 8 DOTS WIDE. In Figure 1 the 2116 output enable is shown being driven by RAM RD. Although this may seem redundant and will slow things down (why not just leave the output enabled?) it is necessary in order to avoid bus conflict when doing a memory write operation.

By expanding on this basic circuit, numerous options such as external attributes, expanded character sets and dynamic RAM may be added to achieve the desired end system. **TMP EXTERNAL CHARACTER GENERATOR** 



7-59



# NS405 TMP Logic Analyzer

# INTRODUCTION

The NS405 TMP is ideally suited for use in Test and Instrumentation equipment as the system or display controller. To demonstrate this, the following note describes how to turn the NS405 Demo Board into a simple 8 bit Logic State Analyzer. Featured in this system is a data capacity of 156 eight bit words, 21 µs data acquisition time, keyboard command entry, UP/DOWN rolling scroll and 24 line data display.

#### SYSTEM ARCHITECTURE

All of the necessary resources to build our system are available in a TMP Demo Board system when normally set up as a data terminal. Commands are entered through the attached ASCII encoded keyboard with data being strobed on the external interrupt. Data words are input through the switch configuration register SW2 by strobing the Light Pen interrupt. Video is output to the attached display monitor. The only real difference between our Logic Analyzer and the Data Terminal is the ROM software in U9 running the TMP. An overview of the system is shown in *Figure 1*.

In order to maximize the available 2k of video RAM, a display line length of 13 was chosen. This yields 157 lines of display information (157  $\times$  13 = 2041), one of which is used to display title information. Thus our display data field consists of 156 lines of information, any 24 of which may be displayed at any given time. On each line is displayed the STEP number, followed by 2 spaces and 8 bits of 1 or 0 information. A typical display pattern is illustrated in Figure 2. By manipulating the pointer registers in the TMP DMA controller, the Title line is made to be stationary while the rest of the screen scrolls. This is accomplished by reversing the roles of the HOME register and Status Section SROW pointer. Specifically HOME points to the last row in memory which holds the title information while the status section is set to start after the display of the first row. Scrolling is accomplished by bumping the SROW pointer up or down 1 line width and checking for end of memory conditions.

National Semiconductor Application Note 369 James Murashige





TL/DD/6970-2

# FIGURE 2. TMP Logic Analyzer Screen Format

#### SYSTEM SOFTWARE

Since the system must rely on external events at several points before proceeding with processing, an interrupt driven approach was taken in structuring the software. A flow-chart for the main program is shown in *Figure 3*. After system initialization there are 2 levels of processing associated with our logic analyzer operation. The first is a wait for an external interrupt signifying a new keyboard command. Referring to the keyboard service routine in *Figure 4*, the key is first read in and decoded as to function. In our simple system them tare and processing associated with the eare only 3 commands:

S or s =Start data acquisition U or u =Scroll display up I or i =Scroll display down



TL/DD/6970-1

The scrolling functions are easily handled in the service routine by bumping the memory pointers and checking for an end of memory condition. A command to start data acquisition moves us to our second level of processing—the actual acquisition and display of data.

In both the keyboard and data acquisition interrupt service routines, flags F0 and F1 are used to pass system status back and forth from the main program. In this way the main program holds at major points while the service routines accomplish their functions. The data acquisition routine does nothing more than read data in from the SW2 port, store it in video memory and check a loop counter to see whether we have read in enough data. Since the Light Pen interrupt is being used, only high to low transitions will initiate an SW2 read. While very little is being done in data acquisition, it is time consuming because it's done in software. A count of instructions yields a worst case processing time of 21  $\mu$ s between data strobes. In addition, since the data isn't latched it must remain stable until the actual read occurs. Following data acquisition, the stored data words are disassembled into their ASCII "1's" and "0's" patterns and the data entires numbered. With data acquisition completed, the program returns to await another keyboard command.

#### SUMMARY

As demonstrated, the NS405 is very effective as a display controller in a video instrumentation system. Certain functions, however, such as data acquisition are better left to dedicated hardware controllers. Nevertheless, the system as presented is still a very useful diagnostic tool. Through small enhancements to the hardware and software, features such as word recognition, number base conversion, wider data words and loop delay may readily be added.



| 1<br>2                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3                                        | .TITLE MAIN, 'TMP LOGIC ANALYZER DEMO'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 5                                        | ; James Murashige 2/09/84                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 6<br>7<br>8<br>9<br>10<br>11<br>12<br>13 | This program turns the TMP Demo board into a simple 8 bit logic analyzer.<br>;Command inputs are entered from the attached ASCII keyboard while data<br>;acquisition takes place through the switch configuration socket, SW2.<br>;The DIP switch may have to be unsoldered from the board. Data is strobed<br>;in with an external clock applied to Light Pen Interrupt on W8A. Each time<br>;data acquisition is started 156 words of 8 bits each are acquired and displayed.<br>;Display is in the form of STEP location and the associated 8 bit 1's and 0's<br>;pattern. |
| 14                                       | ;Commands are S = Start data acqusition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15<br>16                                 | ; U = Scroll display up                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 17                                       | ; I - Scroll display down                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 18                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 19                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 20 07DF                                  | LSTLIN = 07DF ;START OF LAST LINE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 21 07EB                                  | NEMEND = O7EB ;END OF MEMORY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 22 07EC                                  | STLIN = OTEC ; START OF TITLE LINE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 23 0020                                  | VON = 020 ; VIDEO ON                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 24 0000<br>25                            | VOFF = OOO ;VIDEO OFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 26                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 27                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 28 0000                                  | - = OO ;START AT PROGRAM LOCATION O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 29                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 30 0000 0452<br>31                       | RESET: JMP BEGIN ; VECTOR TO RESET CODE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 32 0003                                  | . = 03                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 33                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 34 0003 0412                             | EXI: JMP KEY ;VECTOR TO KEYBOARD COMMAND DECODE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 35                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 36 0007                                  | 07                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 37                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 38<br>39 0007 80                         | INI: ;DATA STROBE INTERRUPT SERVICE<br>MOV A,INTR ;CLEAR OUT INTERRUPT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 40 0008 91                               | MOVX A, OR1 ; GET DATA CHARACTER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 41 0009 80                               | MOVX @RO,A STORE CHARACTER AWAY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 42 000A 98                               | MOVL A, RO ; BUMP RO POINTER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 43 000B 6B                               | ADD A,R3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 44 000C 88<br>45 000D EA11               | MOVL RO,A<br>DJNZ R2,NOTRU ;CHECK IF THROUGH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 46                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 47 OOOF B5                               | CPL F1 ;YES THROUGH, SET INDICATOR BIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 48 0010 35                               | DIS II ;DISABLE LP INTERRUPT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 49                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 50 0011 93<br>51                         | NOTRU: RETR ;RETURN<br>.FORM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 52                                       | KEYBOARD COMMAND DECODE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 53 0012 E1                               | KEY: IN PORT ;KEYBOARD DATA READ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 54 OO13 53DF                             | ANL A, #ODF ; CONVERT LOWER TO UPPER CASE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 55 0015 AA                               | MOV R2,A ;SAVE COPY IN R2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 56 0016 D353                             | XRL A,#'S'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 57 0018 C627<br>58 001A FA               | JZ START ;GOTO START<br>MOV A,R2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 59 001B D355                             | XRL A, #'U'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 60 001D C62B                             | JZ UP ; GOTO SCROLL UP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 61 001F FA                               | MOV A,R2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 62 0020 D349                             | XRL A,#'I'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 63 0022 C63C                             | JZ DOWN ; GOTO SCROLL DOWN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 64 0024 A624<br>65 0026 93               | CKOFF: JNXI CKOFF ;NOT A VALID KEY & WAIT FOR EXI TO GO AWAY<br>RETR ;RETURN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 66                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 67 0027 95                               | START: CPL FO ;START BIT SET                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 68 0028 15                               | DIS XI ;DISABLE FURTHER KEYBOARD INTERRUPTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 69 0029 0424                             | JMP CKOFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 70<br>71 002B 99                         | UP: MOVL A,R1 ;SCROLL UP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 11 0020 33                               | TL/DD/6970-6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                          | 11/10/63/0-6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

72 002C 030D ADD A,#13 ADVANCE TO NEXT ROW 73 002E 89 MOVL R1,A SAVE NEW VALUE 74 002F 0314 ADD A, #L(-L(STLIN)) ;CHECK FOR END OF DISPLAY 75 0031 E2 MOV A, HACC SUBTRACT STLIN FROM A 76 0032 03F8 ADD A, #L(-H(STLIN) - 1) ; CARRY WILL BE SET IF A WAS > OR = NEW VALUE OK, LOAD SROW AND RETURN 77 0034 E639 JNC UPTRU 78 0036 27 CLR A RESET SROW TO BEGINNING 79 0037 C2 MOV HACC.A MOVL R1,A 80 0038 89 81 0039 99 UPTRU: MOVL A,R1 :LOAD R1 INTO SROW 82 003A OE MOV SROW, A 83 003B 93 RETR 84 85 0030 99 DOWN: MOVL A.R1 SCROLL DOWN SUBTRACT TO NEXT ROW 86 003D 03F3 ADD A,#-13 MOV R2.A TEMP SAVE OF LOW ORDER 87 003F AA MOV A, HACC NOW DO UPPER HALF 88 0040 E2 CARRY WILL BE SET IF A WAS 12 OR MORE 89 0041 03FF ADD A, #OFF 90 0043 F64D JC DNTRU ;NEW VALUE OK, LOAD VALUE INTO SROW 91 0045 2307 MOV A, #H(LSTLIN) :RESET SROW TO LAST ROW MOV HACC,A 92 0047 C2 93 0048 23DF MOV A, #L(LSTLIN) 94 004A 89 MOVL R1.A 95 004B OE MOV SROW, A 96 0040 93 RETR 97 004D C2 DNTRU: MOV HACC.A 98 004E FA MOV A,R2 99 004F 89 MOVL R1.A MOV SROW, A 100 0050 OE 101 0051 93 RETR 102 - FORM 103 104 START OF INITIALIZING CODE 105 106 0052 05 BEGIN: SEL MBO 107 0053 C3 SEL RBO 108 0054 15 DIS XI ;INTERRUPTS OFF FOR NOW 109 0055 35 DIS II 110 0056 65 STOP T ;TIMER OFF SET UP TIMING CHAIN FOR DEMO BOARD 111 0057 27 CLR A 112 0058 87 MOV TCP. A MOV A, #103 :HORIZONTAL LENGTH 113 0059 2367 MOV @TCP, A 114 005B B7 115 0050 2300 MOV A, #12 :CHARACTERS/ROW MOV @TCP, A 116 005E B7 ;HORIZONTAL SYNC BEGIN 117 005F 2353 MOV A, #83 MOV @TCP, A 118 0061 B7 ;HORIZONTAL SYNC END 119 0062 2363 MOV A, #99 120 0064 B7 MOV GTCP, A MOV A, #091 ;CHARACTER HEIGHT/ EXTRA SCANS 121 0065 2391 MOV GTCP, A 122 0067 B7 123 0068 231A MOV A, #26 :VERTICAL LENGTH 124 006A B7 MOV @TCP, A MOV A, #24 :VERTICAL BLANK 125 006B 2318 MOV @TCP, A 126 006D B7 127 006E 2362 MOV A, #062 ;VERTICAL SYNC BEGIN/END 128 0070 B7 MOV @TCP. A :STATUS ROW BEGIN 129 0071 2300 MOV A, #00 MOV GTCP, A 130 0073 B7 131 0074 23F4 MOV A, #OF4 :BLINK RATE 132 0076 B7 MOV @TCP, A 133 0077 2330 MOV A, #030 MOV @TCP, A GRAPHICS COLUMN REGISTER 134 0079 B7 135 007A 2336 MOV A, #036 :GRAPHICS ROW REGISTER 136 007C B7 MOV @TCP, A 137 007D 2389 MOV A, #089 **;UNDERLINE SIZE REGISTER** MOV @TCP, A 138 007F B7 139 0080 2309 MOV A, #009 CURSOR SIZE REGISTER MOV GTCP,A 140 0082 B7 141

AN-369

TL/DD/6970-7

142

. FORM 143 144 0083 2304 MOV A. #004 SET SYSTEM CONTROL REGISTER MOV SCR, A ;8 BI, 7 DOTS, DIVIDE 1, SEQUENTIAL LOOKUP 145 0085 55 146 147 0086 27 CLR A :SET VIDEO RAM POINTERS 148 0087 C2 MOV HACC, A ACCUMULATOR CLEARED MOV BEGD, A 149 0088 OD ;SROW WILL BE OUT HOME 150 0089 OE MOV SROW, A MOVL RO, A 151 008A 88 CLEAR MEMORY POINTER MOVL R1, A ;1 I MOV A, #H(MEMEND +1) MOV HACC, A 1 IS SROW IMAGE 152 OO8B 89 153 0080 2307 154 OO8E C2 155 OO8F 23EC MOV A, #L(MEMEND +1) MOV ENDD,A SET END OF MEMORY POINTER 156 0091 00 MOV HOME, A SET POINTER TO TITLE ROW 157 0092 BA MOV A, #OFF 158 0093 23FF 159 0095 C2 MOV HACC, A ;NO CURSOR MOV CURS, A 160 0096 8B MOV ALO, A NO ATTRIBUTES FOR LATCH O 161 0097 30 NO ATTRIBUTES FOR LATCH 1 MOV AL1, A 162 0098 3D CLR FO ;FO IS "START" BIT CLR F1 ;F1 IS "THROUGH" BIT 163 0099 85 164 009A A5 MOV A,#020 165 009B 2320 166 009D 82 MOV MASK, A :SET INTERRUPT MASK 167 168 009E 3456 :CLEAR VIDEO MEMORY CALL MEMCLR 169 ;REENABLE EXTERNAL INTERRUPTS 170 0040 05 EN XI JMP LINNUM ;DISPLAY TITLE INFORMATION 171 00A1 2400 172 173 OOA3 86A3 KEYIN: JNFO KEYIN ;WAIT FOR KEYBOARD INPUT 174 .FORM 175 176 177 :DATA ACQUISITION ROUTINES 178 179 OOA5 85 CLR FO ;CLEAR START BIT 180 00A6 2300 MOV A, #VOFF :VIDEO OFF 181 OOA8 45 MOV VCR, A 182 0049 3456 CALL MEMCLR :CLEAR VIDEO MEMORY 183 00AB 27 CLR A 184 OOAC C2 MOV HACC, A MOV SROW A RESET SROW TO BEGINNING 185 OOAD OE MOV R2, #156 ;SET LOOP COUNTER FOR # WORDS TO READ 186 OOAE BA9C 187 00B0 2305 MOV A,#5 188 00B2 88 MOVL RO.A :SET MEMORY POINTER TO FIRST DATA DEPOSIT 189 00B3 23C0 MOV A. #OCO MOV HACC, A 190 00B5 C2 191 OOB6 89 MOVL R1,A :LOAD R1 WITH ADDRESS OF SWITCH REGISTER 192 00B7 BBOD MOV R3.#13 :LOAD R3 WITH POINTER BUMP CONSTANT CLEAR OUT ANY PENDING INTERRUPTS 193 00B9 8C MOV A, INTR 194 OOBA 25 EN II REENABLE LP INTERRUPT 195 196 OOBB 66BB :WAIT FOR "THROUGH" BIT TO SET DATAIN: JNF1 DATAIN 197 ;DISASSEMBLE DATA INTO DISPLAY FORMAT 198 RESET "THROUGH" 199 OOBD A5 CLR F1 200 OOBE BA9C MOV R2,#156 ;DISASSEMBLE DATA, LOAD WORD COUNTER 201 0000 27 CLR A 202 0001 02 MOV HACC.A MOV A,#5 203 0002 2305 ;SET MEMORY POINTER TO FIRST DATA DEPOSIT 204 0004 88 MOVL RO, A 205 00C5 BB08 MOV R3.#8 DO 8 BITS 206 0007 90 UNASS: MOVX A, GRO :LOAD IN DATA BYTE 207 00C8 04CB JMP DEPST RETRIV: MOV A,R4 :RETRIEVE CHARACTER 208 00CA FC 209 OOCB F7 DEPST: RLC A ;ROTATE BIT INTO CARRY ;TEMPOI STORE ;STORE A "1" MOV A,#'O' MOV R4,A 210 00CC AC ;TEMPORARY SAVE 211 OOCD F6D3 STORE A "O" 212 OOCF 2330 JMP CONT 213 OOD1 04D5 TL/DD/6970-8

214 00D3 2331 ONE: MOV A.#'1' STORE A "1" 215 0005 80 CONT: MOVX GRO.A STORE CHARACTER INCL RO ;INCREMENT POINTER 216 0006 38 DJNZ R3, RETRIV ; CONTINUE IF WORD NOT DONE 217 00D7 EBCA 218 219 00D9 98 MOVL A.RO BUMP MEMORY POINTER TO NEXT WORD 220 00DA 0305 ADD A,#5 221 OODC 88 MOVL RO, A MOV R3.#8 RESET BIT COUNTER 222 OODD BB08 CONTINUE IF ALL LOCATIONS NOT DONE 223 OODF EAC7 DJNZ R2.UNASS JUMP TO NEXT PAGE JMP LINNUM 224 00E1 2400 . FORM 225 ;LINE NUMBERING ROUTINES 226 . = 0100 227 0100 228 229 0100 27 LINNUM: CLR A 230 0101 02 MOV HACC.A 231 0102 88 MOVL RO.A CLEAR MEMORY POINTER 232 0103 BA9C MOV R2,#156 :DO 156 LINES MOV R3,#10 SET HUNDREDS POINTER 233 0105 BBOA 234 0107 BCOA MOV R4.#10 ;SET TENS POINTER MOV R5.#10 SET ONES POINTER 235 0109 BDOA 236 NUMLP: MOV A,R3 CALL LKUP 237 010B FB :LOOK UP HUNDREDS ASCII CODE 238 010C 343B STORE HUNDREDS ASCII CODE 239 010E 80 MOVX @RO,A 240 010F 38 INCL RO MOV A,R4 :LOOK UP TENS ASCII CODE 241 0110 FC CALL LKUP 242 0111 343B 243 0113 80 MOVX @RO.A :STORE TENS ASCII CODE 244 0114 38 INCL RO MOV A,R5 :LOOK UP ONES ASCII CODE 245 0115 FD 246 0116 343B CALL LKUP 247 0118 80 MOVX WRO,A :STORE ONES ASCII CODE 248 ; BUMP RO TO NEXT LINE MOVL A,RO 249 0119 98 250 011A 030B ADD A,#11 251 0110 88 MOVL RO,A 252 253 011D ED26 DJNZ R5.CONNUM INCREMENT ONES POINTER MUST NOW INCREMENT TENS 254 011F BDOA MOV R5,#10 DJNZ R4, CONNUM ;INCREMENT TENS POINTER 255 0121 EC26 256 0123 BCOA MOV R4.#10 MUST NOW INCREMENT HUNDREDS 257 0125 CB DEC R3 258 259 0126 EAOB CONNUM: DJNZ R2, NUMLP :DO ANOTHER ROW 260 PUT UP TITLE LINE 261 0128 94 MOV A, HOME 262 0129 88 MOVL RO,A ;LOOKUP 13 CHARACTERS 263 012A BAOD MOV R2.#13 :LOAD POINTER TO ASCII TITLE STRING 264 012C BB49 MOV R3,#L(TITLE) 265 266 012E FB TITLP: MOV A,R3 MOVP A, @A 267 012F B3 MOVX @RO,A 268 0130 80 INCL RO 269 0131 38 270 0132 1B TNC R3 DJNZ R2,TITLP 271 0133 EA2E 272 . FORM 273 274 275 0135 2320 MOV A, #VON TURN VIDEO BACK ON MOV VCR,A 276 0137 45 ;REENABLE KEYBOARD INTERRUPTS 277 0138 05 EN XI ;RETURN AND WAIT FOR NEXT START 278 0139 0443 JMP KEYIN 279 SUBROUTINES 280

| ADD  | A,#L(CHAR) | -1;   |    |       |        |  |
|------|------------|-------|----|-------|--------|--|
| MOVP | A,@A       | ;LOOK | UP | ASCII | NUMBER |  |
| RETR | : RE       | TURN  |    |       |        |  |

281 282 013B 033E

283 013D B3 284 013E 93 LKUP:

TL/DD/6970-9

| 285                                                                                                                                                                                                           |                                                           |                                                                                                                                                                  |                                                           |                                                    |                                              |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|----------------------------------------------------|----------------------------------------------|
| 286 013F 39                                                                                                                                                                                                   | CHAR:                                                     | .BYTE '987654'                                                                                                                                                   | 210'                                                      |                                                    |                                              |
| 287                                                                                                                                                                                                           |                                                           |                                                                                                                                                                  |                                                           |                                                    |                                              |
| 288 0149 53                                                                                                                                                                                                   | TITLE:                                                    | .BYTE 'STEP 7                                                                                                                                                    | DATA O'                                                   |                                                    |                                              |
| 289                                                                                                                                                                                                           |                                                           |                                                                                                                                                                  |                                                           |                                                    |                                              |
| 290 0156 27                                                                                                                                                                                                   | MEMCLR:                                                   | CLR A :VIDEC                                                                                                                                                     | MEMORY CLE                                                | AR LOOP                                            |                                              |
| 291 0157 C2                                                                                                                                                                                                   |                                                           | MOV HACC.A                                                                                                                                                       |                                                           |                                                    |                                              |
| 292 0158 88                                                                                                                                                                                                   |                                                           | MOVL RO, A                                                                                                                                                       | PO CLEAR                                                  | on onenn                                           |                                              |
| 293 0159 BA00                                                                                                                                                                                                 | 1                                                         | MOV R2.#O                                                                                                                                                        | TINNER LOO                                                | P COUNTE                                           | የ ዓምም                                        |
| 294 015B BB08                                                                                                                                                                                                 |                                                           | MOV R3, #8                                                                                                                                                       | OUTER LOO                                                 | P COUNTE                                           | RSET                                         |
| 295 015D 2320                                                                                                                                                                                                 |                                                           | MOV A.#020                                                                                                                                                       | SPACE CHA                                                 | RACTER                                             |                                              |
| 296 015F 80                                                                                                                                                                                                   |                                                           |                                                                                                                                                                  |                                                           |                                                    | D                                            |
| 297 0160 38                                                                                                                                                                                                   |                                                           | INCL RO ;INCRE                                                                                                                                                   |                                                           |                                                    | n                                            |
| 298 0161 EA5F                                                                                                                                                                                                 |                                                           | DJNZ R2.MCLRLP                                                                                                                                                   |                                                           |                                                    |                                              |
| 299 0163 BAOO                                                                                                                                                                                                 |                                                           | MOV R2.#O                                                                                                                                                        |                                                           |                                                    |                                              |
| 300 0165 EB5F                                                                                                                                                                                                 |                                                           | MUV K2,#U                                                                                                                                                        | RELOAD IN                                                 | NER LOOP                                           | COUNTER                                      |
| 200 0165 EB5F                                                                                                                                                                                                 |                                                           | DJNZ R5, MCLRL                                                                                                                                                   | ;TEST OUTE                                                | R LOOP                                             |                                              |
| 301 0167 93                                                                                                                                                                                                   |                                                           | RETR ;TH                                                                                                                                                         | ROUGH, RETU                                               | RN                                                 |                                              |
|                                                                                                                                                                                                               |                                                           |                                                                                                                                                                  |                                                           |                                                    |                                              |
| 302                                                                                                                                                                                                           |                                                           |                                                                                                                                                                  |                                                           |                                                    |                                              |
| 303                                                                                                                                                                                                           | • END                                                     |                                                                                                                                                                  |                                                           |                                                    |                                              |
| 303<br>BEGIN 0052                                                                                                                                                                                             | CHAR                                                      | O13F CKOFI                                                                                                                                                       |                                                           | CONNUM                                             | 0126                                         |
| 303<br>BEGIN 0052<br>CONT 00D5                                                                                                                                                                                | CHAR<br>DATAIN                                            | OOBB DEPS                                                                                                                                                        | OOCB                                                      | DNTRU                                              | 004D                                         |
| 303<br>BEGIN 0052<br>CONT 00D5<br>DOWN 003C                                                                                                                                                                   | CHAR<br>DATAIN<br>EXI                                     | OOBB DEPS<br>OOO3 * INI                                                                                                                                          | 000B<br>0007 *                                            | DNTRU<br>KEY                                       | 004D<br>0012                                 |
| 303<br>BEGIN 0052<br>CONT 00D5<br>DOWN 003C<br>KEYIN 00A3                                                                                                                                                     | CHAR<br>DATAIN<br>EXI                                     | 00BB DEPS<br>0003 * INI<br>0100 LKUP                                                                                                                             | 00CB<br>0007 *<br>013B                                    | DNTRU<br>KEY<br>LSTLIN                             | 004D<br>0012<br>07DF                         |
| 303<br>BEGIN 0052<br>CONT 00D5<br>DOWN 003C                                                                                                                                                                   | CHAR<br>DATAIN<br>EXI<br>LINNUM                           | 00BB DEPS<br>0003 * INI<br>0100 LKUP                                                                                                                             | 000CB<br>0007 *<br>013B<br>ND 07EB                        | DNTRU<br>KEY<br>LSTLIN<br>NOTRU                    | 004D<br>0012<br>07DF<br>0011                 |
| 303<br>BEGIN 0052<br>CONT 00D5<br>DOWN 003C<br>KEYIN 00A3                                                                                                                                                     | CHAR<br>DATAIN<br>EXI<br>LINNUM<br>MEMCLR                 | OOBB         DEPS:           OOO3 *         INI           O100         LKUP           O156         MEMEN                                                         | 000CB<br>0007 *<br>013B<br>ND 07EB                        | DNTRU<br>KEY<br>LSTLIN<br>NOTRU                    | 004D<br>0012<br>07DF                         |
| 303<br>BEGIN 0052<br>CONT 00D5<br>DOWN 003C<br>KEYIN 00A3<br>MCLRLP 015F                                                                                                                                      | CHAR<br>DATAIN<br>EXI<br>LINNUM<br>MEMCLR                 | OOBB         DEPS:           OOO3 *         INI           O100         LKUP           O156         MEMEN                                                         | C OOCB<br>0007 *<br>013B<br>ND 07EB<br>C 0000 *           | DNTRU<br>KEY<br>LSTLIN<br>NOTRU<br>RETRIV          | 004D<br>0012<br>07DF<br>0011                 |
| 303<br>BEGIN 0052<br>CONT 00D5<br>DOWN 003C<br>KEYIN 00A3<br>MCLRLP 015F<br>NUMLP 010B                                                                                                                        | CHAR<br>DATAIN<br>EXI<br>LINNUM<br>MEMCLR<br>ONE          | OOBB         DEPS'           OOO3         INI           O100         LKUP           O156         MEMEL           OOD3         RESE'                              | C 00CB<br>0007 *<br>013B<br>ND 07EB<br>C 0000 *<br>E 0149 | DNTRU<br>KEY<br>LSTLIN<br>NOTRU<br>RETRIV          | 004D<br>0012<br>07DF<br>0011<br>00CA         |
| 303           BEGIN         0052           CONT         00D5           DOWN         003C           KEYIN         00A3           MCLRLP         015F           NUMLP         010B           START         0027 | CHAR<br>DATAIN<br>EXI<br>LINNUM<br>MEMCLR<br>ONE<br>STLIN | OOBB         DEPS?           OOO3         INI           O100         LKUP           O156         MEMEN           OOD3         RESE?           O7EC         TITLL | C 00CB<br>0007 *<br>013B<br>ND 07EB<br>C 0000 *<br>E 0149 | DNTRU<br>KEY<br>LSTLIN<br>NOTRU<br>RETRIV<br>TITLP | 004D<br>0012<br>07DF<br>0011<br>00CA<br>012E |

NO ERROR LINES

328 ROM BYTES USED

SOURCE CHECKSUM = 40D8 OBJECT CHECKSUM = 0649

INPUT FILE A:LOGIC.MAC LISTING FILE A:LOGIC.PRN OBJECT FILE A:LOGIC.LM

TL/DD/6970-10

# **Building an Inexpensive but Powerful Color Terminal**

Historically, the design of a color CRT terminal has involved a significant upgrade of the circuit for a monochrome terminal. The result was a stiff increase in price for the electronics as well as for the monitor when going from monochrome to color. As a result, most companies built monochrome terminals and a few built color terminals only.

On the personal computer front where separate monitors are common, manufacturers have started to offer video cards which will support either a monochrome or a color monitor. More recently, color terminals have begun to appear which are extensions of monochrome terminal families. They require a board full of I.C.s for even the most space efficient designs. But now, using the TMP, you can do the same job with just one VLSI chip and a half dozen 7400 family TTL chips.

The National Semiconductor NS405 Series Terminal Management Processor (TMP) was originally conceived as a monochrome "terminal on a chip". However, the design team took special pains to build in "hooks" to allow users to augment the basic features of the TMP. In particular the TMP supports almost unlimited attribute expansion, and therein lies the key to adding color to a TMP-based terminal. Even nicer, the addition of color attributes does not sacrifice any of the other powerful features provided by the TMP.

Here, we will delve into a little of the mechanics of TMP attribute handling. The diagram in Figure 1 shows the path of the attribute bits (normally 8) from the display memory

National Semiconductor **Application Note 374** Leigh Cropper



into the TMP, through the FIFO, the attribute control logic, and finally to the video output section where the attributes are combined with the serialized video output.

Because the display memory space may be large (up to 64k x 16), it is easy to store many more attribute bits by adding display memory chips. A 2k x 8 RAM will hold 8 attribute bits for every location on an 80 row by 25 line display. However, in order to implement color attributes, three problems must be examined: (1) how to let both the CPU and the display controller address the extra attribute memory in a practical manner: (2) how to imitate the behavior of the internal FIFO and maintain proper synchronization; and (3) how to combine the color attributes and the video output signal.

Before addressing the three problems in detail, a discussion of the number and type of color attributes is in order. The simplest type of color display would require only 3 bits (red, green, and blue). That allows a character to be displayed in any of 7 colors over a black background or, when reverse video is asserted, the character is black on a colored background. For independent control of both the foreground and background colors, 6 bits are required. To get more shades of color, add more bits.

A practical approach employs a 2k x 8 RAM for the color attribute memory. Three of the bits control the foreground color, three control the background color and the remaining two may be used to adjust intensity (1 for foreground and 1 for background).



FIGURE 1. TMP Attribute Processing

TL/DD/7923-1

Now let's tackle the problems one by one.

 COLOR ATTRIBUTE MEMORY ADDRESSING. When fetching data for the display, we need to get 24 bits in parallel (8 data, 8 attribute and 8 color attribute). But when the CPU accesses memory, it can handle only 16 bits at a time, so the CPU must be able to read and write color attributes in a different bank of memory from that where the data and ordinary attributes are stored. For an 80 character by 25 row display the memory could be mapped as shown in *Figures 2* and *3*:

**AN-374** 



During a display refresh cycle the color attribute memory is selected by the low bank select (the same select signal that enables the data and attribute memories). However, the color attribute bits drive the external FIFO's, whereas the output from the other two memories is routed through the TMP. The data path from the color attribute memory to the TMP is buffered by an octal transceiver which is disabled when the low bank is selected. During a CPU access to color attribute memory, the high bank select enables the color attribute memory and the octal transceiver. The direction control of the transceiver is controlled by the RAM RD signal from the TMP.

- 2. EXTERNAL FIFO SYNCHRONIZATION. The TMP provides FI CLK (FIFO Input Clock) and FO CLK (FIFO Output clock) signals which may be used to clock an external FIFO. The FI CLK signal is identical in timing and duty cycle to the RAM RD signal except that FI CLK is disabled (stays high) when the CPU accesses display memory. When the 74LS224 is used as an external FIFO, FI CLK must be inverted. The rising edge of FO CLK occurs when output of the internal FIFO is loaded into the internal dot shifter. The FO CLK is used to empty a word from the external FIFO and clock it into an octal latch.
- 3. COMBINING COLOR ATTRIBUTES WITH VIDEO. When using foreground and background color attributes, a 74LS157 multiplexer works nicely to switch between the two. The eight color attribute bits from the latch are separated into groups of four. The video output signal is used to switch the multiplexer. When the video output is high, foreground attributes are selected: and when the

video output is low, background attributes are selected. The outputs of the multiplexer (red, green, blue and intensity) directly drive the color monitor inputs. A minor problem arises because the video output from the TMP already includes the blanking signal. That makes it impossible to differentiate between a series of spaces in the middle of the screen and the horizontal blanking interval. In either case, the video output is low. The easiest solution is handled in software. Let's assume that we want an 80 column display and are using three 2K x 8 memory chips for the data, attribute and color memories. We set up the TMP for 81 columns and then configure the program so that the 81st column always contains a space code with all attribute bits off (including color). That way the background color will always be black during both horizontal and vertical retrace. The cost is 25 locations in each of the memories, but we can afford that many because an 80 x 25 display requires 2000 locations, leaving 48 free.

# A Practical Example

Here we will present a color terminal circuit with the associated program as an example of what you may want to do. We started with the terminal design of the TMP development board. See the block diagram in *Figure 5*.

The block diagram of the color terminal (with the old portions of the original monochrome terminal unshaded and the new color circuits shaded) appears in *Figure 6*. The new circuitry was added in the prototyping area of the development board.





**₽75-NA** 

## COLOR ATTRIBUTE BIT ASSIGNMENTS The bit assignments are:

- Bit 0 Blue foreground
- Bit 1 Green foreground
- Bit 2 Red foreground
- Bit 3 Blue background
- Bit 4 --- Green background
- Bit 5 Red background
- Bit 6 Foreground intensity
- Bit 7 Background intensity

Without using the intensity control bits you get 8 foreground colors: red, green, blue, magenta, cyan, yellow, white, and black (beam off). The same 8 colors may be independently selected for the background. There are several RGB monitors available in the moderate price range with sufficient bandwidth to work with a 12 MHz TMP. Some of them include a separate intensity (or luminence) input. Others include internal decoding circuitry which provides the ability to handle 4 bits of color input and provide as many as 16 different colors.

The demonstration program which runs on the development board allows limited color support. The Escape, V sequence from the keyboard or the receiver prompts the program to treat the next character received as an eight bit color attribute byte with the bit assignments as listed above. That byte is written to the color attribute memory as each succeeding character is received, until another escape, V sequence is encountered. The table which follows includes the foreground and background color combinations for characters which can be entered from the keyboard, but it ignores the effect of the 2 high-order bits (foreground and background intensity).

#### COLOR COMBINATIONS FOR RGB MONITORS

Table I gives the Foreground/Background color combinations that occur when using the '<ESC> Vv' Escape sequence. To set the current color attribute, all that you need to do is select the color combination from the Table below, and send it to the NS405 as part of the <ESC> Vx sequence. For example, '<ESC> V"' causes the Foreground color to be green and the Background color to be red... not all that pleasing, to my tastes, but choose what you will.

| Char | Fore/Back       | Char | Fore/Back     | Char | Fore/Back     |
|------|-----------------|------|---------------|------|---------------|
| sp   | Black/Red       | 6    | Yellow/Yellow | к    | Cyan/Blue     |
| 1    | Blue/Red        | 7    | White/Yellow  | L    | Red/Blue      |
| "    | Green/Red       | 8    | Black/White   | м    | Magenta/Blue  |
| #    | Cyan/Red        | 9    | Blue/White    | • N  | Yellow/Blue   |
| \$   | Red/Red         | :    | Green/White   | 0    | White/Blue    |
| %    | Magenta/Red     | ;    | Cyan/White    | Р    | Black/Green   |
| &    | Yellow/Red      | <    | Red/White     | Q    | Blue/Green    |
| ,    | White/Red       | =    | Magenta/White | R    | Green/Green   |
| (    | Black/Magenta   | >    | Yellow/White  | s    | Cyan/Green    |
| )    | Blue/Magenta    | ?    | White/White   | Т    | Red/Green     |
|      | Green/Magenta   | e    | Black/Black   | υ    | Magenta/Green |
| +    | Cyan/Magenta    | A    | Blue/Black    | l v  | Yellow/Green  |
| ,    | Red/Magenta     | В    | Green/Black   | w    | White/Green   |
| -    | Magenta/Magenta | c    | Cyan/Black    | x    | Black/Cyan    |
|      | Yellow/Magenta  | D    | Red/Black     | Y    | Blue/Cyan     |
| 1    | White/Magenta   | E    | Magenta/Black | z    | Green/Cyan    |
| 0    | Black/Yellow    | F    | Yellow/Black  | 1    | Cyan/Cyan     |
| 1    | Blue/Yellow     | G    | White/Blue    | N 1  | Red/Cyan      |
| 2    | Green/Yellow    | н    | Black/Blue    | 1    | Magenta/Cyan  |
| 3    | Cyan/Yellow     | 1    | Blue/Blue     |      | Yellow/Cyan   |
| 4    | Red/Yellow      | J    | Green/Blue    |      | White/Cyan    |
| 5    | Magenta/Yellow  |      |               |      | •             |

TABLE I Foreground/Background Color Combinations

# TMP Extended Program Memory Application Note

National Semiconductor Application Note 399 Richard Lazovick



N-399

## OVERVIEW/INTRODUCTION

The purpose of this application note is to describe methods for expanding the program memory of the NS405 series TERMINAL MANAGEMENT PROCESSOR (TMP) and to provide direction in software techniques for utilizing the expanded memory efficiently. The chip has a built-in capability of addressing up to 8k of external program memory (ROM), via the ROM Expand Bus, and 64k of video display memory (RAM), via the System Bus. Although 8k of program memory is sufficient for most applications there are many applications, such as emulating multiple terminals or using many look-up tables, that require still more memory. However, it is very rare that the entire 64k of video RAM is used since that is more than enough memory to store two screens of data in the pixel mode or thirty-two screens of data in the alphanumeric/block graphics mode. Therefore it is practical to use a video memory address to switch between two or more 8k memory arrays.

The idea behind using a bank select switch to change from one memory array to another is not new, nor is it difficult, and when implemented properly it can be a very useful tool. The TMP has all the necessary control signals to make both the software and hardware straight-forward.



## SOFTWARE

For purposes of demonstration it will be easier to look at the software aspects of using an array select switch first, then designing the hardware to implement it.

The easiest case occurs if we use less than 16k of display memory. Then we have two system bus address lines available to select either of our two arrays. To switch arrays all we have to do is read from (or write to) an address that uses the address line you wish to toggle. It is safer to read from the address since we do not want to change data in memory at the location addressed by the lower order address lines.

Suppose we choose SB14 to select the low order array and SB15 to select the high order array. The program steps we would go through to switch from the low array to the high array could be:

| MOV  | A,#080 | ;Load HACC w/ 80H to set SB15 HI |
|------|--------|----------------------------------|
| MOV  | HACC,A | ;and set SB14 LO. We do not care |
| MOVL | RO,A   | ;about the other address bits.   |
| MOVX | A,@RO  | ;SB15 goes HI.                   |

In general we will want to switch arrays several times, and we will want to be able to conveniently control the destination address in the new array.

Since it is very cumbersome to rewrite the whole sequence everytime, let's mimic the internal select memory bank command (SEL MBx) by using a subroutine and a CALL followed by a JMP to conveniently control our array switching.

|        | CALL        | SELHA                             | ;Select HI order array.                                                                                                                                  |
|--------|-------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | JMP         | HERE                              | ;Jump to HERE in new array.                                                                                                                              |
| SELHA: | MOA<br>WOAT | A,#080<br>HACC,A<br>R0,A<br>A,@R0 | ;Load HACC w/ 80H to set SB15 HI<br>;and set SB14 LO. We do not care<br>;about the other address bits.<br>;SB15 goes HI.<br>;Return to execute the jump. |

Now each time we switch to the high order array all we have to do is execute a CALL and a JMP.



Note 1: Enable ROM output drivers.

TL/DD/8430-2

Note 2: ROM address available.

Note 3: RE bus addresses changes during rising edge of ALE and are stable by falling edge.

Note 4: No PSEN signal present during last cycle of MOVX instruction, however PSEN is active during both RET cycles.

AN-399

#### HARDWARE

Now that we have made the software simple and straightforward we have to look at what hardware is necessary to implement it.

- We want to: 1) create two mutually exclusive enable signals—one for each array,
  - be able to easily use and latch the address line signals, and
  - delay the actual switching of arrays until after the jump instruction, with the new address, is read into the TMP from the old array.

Looking at the program we see that the system bus chang-

es after the MOVX instruction with the RET and JMP instructions still to be read in from memory before we actually want to switch arrays. Each instruction takes two cycles, therefore we want to delay our array switching signal by four cycles. Looking at all the output signals on the TMP there are two possible signals to use as a clock to delay the array switching signal. These signals are <u>PSEN</u> and ALE (see System Signals Timing Diagram).

The main disadvantage of using ALE is that whereas we want a rising edge to clock the flip-flops used for the delay, the ROM addresses are not stable until the falling edge of ALE. Therefore, we save one inverter by using  $\overline{\text{PSEN}}$ .

One possible circuit implementation is shown below:



The first flip-flop latches one of the two system bus signals and the next four delay the array switching signal by four PSEN cycles. The two inverters are there so that we trigger off a ONE on the address. If the system bus was configured as a 16 bit address/data bus (bit 4 of SCR set) then the latched address lines would have to be used. Since it is always desirable to have the flip-flops in a known state at power up, some sort of reset circuitry should be used (e.g., by tying the power up reset circuit to the clear inputs on the flip-flops), or both arrays should have identical reset sequences that include setting the flip-flops to a known state.

# use and the hardware to implement it, let's look at what is actually happening (see Array Switching Timing Diagram 1). The system bus line switches after the first cycle of the MOVX instruction, but there is no PSEN during the second cycle. Then there are two PSEN signals during the RET instruction and two PSEN signals during the JMP instruction. Just after the second byte of the JMP is read into the TMP, the arrays are switched, the PC gets loaded with the new address, and the program continues execution as normal in the new array from the address indicated in the JMP instruction. Be sure you understand the Array Switching Timing Diagram 1 before continuing.

#### LOOKING IN DEPTH

Now that we have the basic software format we are going to



# ADDENDUMS

**AN-399** 

Although it can be a problem when trying to execute a call across array boundaries, the problem can be easily overcome as can the confusion that arises when many array switchings occur. All that one needs to do is to organize the program memory efficiently. One such scheme would be to set aside a block of memory in each bank, such as the last page to use for memory mapping. For example if we wanted to jump from location HOME in the LO array to location HERE in the HI array and then back to HOME we could map our memory as shown below:

# Lo Array

Hi Array

# MAIN PROGRAM:

|      |       | •   |      |
|------|-------|-----|------|
|      |       | •   |      |
| 0500 | HOME: | JMP | HERE |
|      |       | •   |      |
|      |       | •   |      |
|      |       |     |      |

|      |        | -   |      |
|------|--------|-----|------|
|      |        | •   |      |
|      |        | •   |      |
| 0680 | HERE : | NOP |      |
| 0681 |        | JMP | HOME |
|      |        | •   |      |
|      |        | •   |      |
|      |        | •   |      |
|      |        |     |      |
|      |        |     |      |

#### ARRAY SWITCHING SUBROUTINE:

| 0700 | SELHA: | MOV   | A,#080 | 0700 | SELLA: | NOM  | A,#040 |
|------|--------|-------|--------|------|--------|------|--------|
| 0702 |        | MOV   | HACC,A | 0702 |        | MON  | HACC,A |
| 0703 |        | MOVL, | RO,A   | 0703 |        | WOAP | RO,A   |
| 0704 |        | MOVX  | A,@RO  | 0704 |        | MOAX | A,RO   |
| 0705 |        | NOP   |        | 0705 |        | NOP  |        |
| 0706 |        | NOP   |        | 0706 |        | NOP  |        |
| 0707 |        | RET   |        | 0707 |        | RET  |        |

#### MEMORY MAP:

| 070A HERE:<br>070C<br>070E<br>0710 | CALL SELHA<br>JMP HOME<br>(CALL SELHA)<br>(JMP addr) | 070A HOMI<br>070C<br>070E<br>0710 | E: CALL SELLA<br>JMP HERE<br>(CALL SELHA)<br>(JMP addr) | TL/DD/8430-6 |
|------------------------------------|------------------------------------------------------|-----------------------------------|---------------------------------------------------------|--------------|
|                                    | •                                                    |                                   | •                                                       |              |
|                                    | •                                                    |                                   | •                                                       |              |
|                                    | •                                                    |                                   | •                                                       |              |

Note: The arrows show which JMP corresponds to which subroutine call. For example the JMP HOME at location 070C in the LO ARRAY corresponds to the CALL at location 070A in the HI ARRAY. The ()'s show how the CALL's and JMP's can be strung together in a neat pattern.

Notice that there are two NOP's in the subroutine. Since the JMP after the CALL was moved to the new array the two NOP's were added to the subroutine so that the actual array switching occurs just after the completion of the RET instruction. The PC is then loaded with the new jump value, loaded in from the new array, and we continue execution as expected. Be sure to understand the timing before going any further (see Array Switching Diagram 2). The way the memory map is set up it is easy to organize and keep track of jumps using the pattern indicated in the example. This method also eliminates any problems with the assembler searching for undefined labels.



Since there are two extra NOP's in the switching array subroutine the hardware can now be simplified and the system speed increased by removing two of the flip-flops from the chain. Through the use of the SEL MBx commands the memory map can be located in any page of any memory bank. For example if we wanted to jump to location HERE in memory bank 2 of the HI array from memory bank 1 of the LO array (after having removed two flip-flops) we could map our memory as shown below:

| Lo Array       |          |        |        |      | Hi Array |      |        |  |
|----------------|----------|--------|--------|------|----------|------|--------|--|
| ARRAY SWITCHIN | G SUBROI | JTINE: |        |      |          |      |        |  |
| 0700           | SELHA:   | MOV    | A,#080 | 0700 | SELLA:   | мол  | A,#040 |  |
| 0702           |          | MOV    | HACC,A | 0702 |          | MOV  | HACC,A |  |
| 0703           |          | MOVL   | RO,A   | 0703 |          | MOVL | RO,A   |  |
| 0704           |          | MOVX   | A,@R0  | 0704 |          | MOVX | A,@R0  |  |
| 0705           |          | RET    |        | 0705 |          | RET  |        |  |
| MEMORY MAP:    |          |        |        |      |          |      |        |  |
| 070A           | HERE :   | CALL   | SELHA  | 070A |          |      |        |  |
| 0700           |          |        |        | 0700 |          | SEL  | MB2    |  |
| 070E           |          |        |        | 070E |          | JMP  | HERE   |  |
| MAIN PROGRAM:  |          |        |        |      |          |      |        |  |
| 0800           | HOME :   | SEL    | мво    |      |          |      |        |  |
| 0801           |          | JMP    | HERE   |      |          |      |        |  |
|                |          |        |        | 1000 | HERE :   | NOP  |        |  |

If a call into the other array is necessary a similar pattern to that above could be used. Start by replacing the JMP's with CALL's to the desired subroutine and appropriately placing returns. For example (here it comes) if we wanted to CALL HOME from HERE we could memory map as shown below.



Since calling between different memory banks is not straight forward it is advisable to be very careful when doing it, or to limit calls between arrays only to those that reside in the same memory bank.

#### HELPFUL HINTS

These schemes can all be modified to multiple arrays and easier or fancier mappings, however there are a few things to keep in mind.

- If using a system bus address line to toggle the array, don't use that line as part of an actual display memory address.
- 2) The MOVX instruction can require more than two cycles depending on system bus contention, however we are only concerned with the last two cycles and the <u>PSEN</u> signals that occur after the system bus line changes.
- If using interrupts—disable them while switching arrays and keep all time critical routines in the same array.
- 4) A demux or decoder can be used to select memory arrays or decode address lines when more than two 8k arrays are implemented or more than 16k of video RAM is being used.

- If extra memory is needed, but a good deal of the program memory is data storage, the data could be stored in the video memory space instead of implementing a new array.
- 6) If the TMP is going to be used in a noisy environment or the system bus is configured as a 16 bit bidirectional bus a synchronous latch should be used to assure stable levels on SB14 and SB15.
- 7) The given array switching circuit can be implemented with the demo board by wiring it into an extension board that can be plugged into the prom socket U9. Wire the two new proms in parallel with each other and with a cable that can plug directly into the prom socket. However, instead of using pin 20 from the demo board, use the two array enable lines as the chip enables for the 2764 proms.

Also use SB12 and SB13 instead of SB14 and SB15.