# 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 DMA Controller - Interrupt Controller - Character Generator - Parallel I/O Controller - Character Gener - Timer • UART In addition the NS405 includes powerful attribute logic, two 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. # **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 - m 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 # **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 All Input or Output Voltages with Respect to V<sub>SS</sub>\* -65°C to +150°C -0.5V to +7.0V Power Dissipation ESD \*EA, SI and VSYNC may be subjected to V<sub>SS</sub> + 15V. 2000V 1.5W 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 Character- # **DC Electrical Characteristics** $T_A = 0$ °C to +70°C, $V_{CC} = +5V \pm 10\%$ , $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 | Vcc | V | | V <sub>IL2</sub> | 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 | | V <sub>OL</sub> | 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) | l <sub>OH</sub> = -125 μA | 2.4 | Vcc | v | | VoL | Output Low Voltage (INTENS, VO) | I <sub>OI</sub> = 5.0 mA | i | 0.4 | v | | V <sub>OH</sub> | Output High Voltage (INTENS, VO) | l <sub>OH</sub> = -500 μA | 2.4 | | v | | I <sub>IL</sub> | Input Leakage Current (EA, INT, SI) | V <sub>SS</sub> ≤ V <sub>IN</sub> ≤ V <sub>CC</sub> | | ±10 | μА | | loL | Output Leakage Current<br>(ROM Expand Bus, High Impedance State) | V <sub>CC</sub> ≥ V <sub>IN</sub> ≥ V <sub>SS</sub> + 0.45 | | ±10 | μΑ | | l <sub>OL</sub> | 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$ °C to +70°C, $V_{CC} = +5V \pm 10$ %, $V_{SS} = 0$ V, unless otherwise specified | Symbol | Parameter | Min | Max | Units | |------------------|-------------------------------------------------------|------|-------|-------| | AND ROM EX | (PAND BUS TIMING | | | | | FXTAL | Crystal Frequency | 3 | 18 | MHz | | F <sub>CPU</sub> | CPU Frequency | 3 | 12 | MHz | | tcy | CPU Cycle Time | 1.25 | 7.5 | μs | | t <sub>DF</sub> | Video Dot Time | 55.5 | 333.3 | ns | | t <sub>LL</sub> | ALE Pulse Width (Note 1) | 125 | | ns | | t <sub>AL</sub> | Address Setup to ALE (Note 1) | 55 | | ns | | tLA | Address Hold from ALE (Note 1) | 40 | | ns | | tcc | 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 | | t <sub>AFC</sub> | 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 | # **AC Electrical Characteristics** $T_A = 0$ °C to +70°C, $V_{CC} = +5V \pm 10$ %, $V_{SS} = 0$ V, unless otherwise specified (Continued) | Symbol | Parameter | Min | Max | Units | |------------------|--------------------------------------------|-----|-----|-------| | EM 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 | | tard | Data Access from RAM RD (Note 1) | | 140 | ns | | t <sub>RDR</sub> | Data Hold from RAM RD (Notes 1, 4) | 0 | 60 | ns | | twFl | 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) | 20 | | ns | | O 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 | | t <sub>FOV</sub> | FIFO Out Clock to Dot 0 (Note 1) | | 15 | ns | | twfoh | FIFO Out Clock Width High (Note 1, Note 2) | 55 | 165 | ns | <sup>\*1/3</sup> CPU cycle. Note 1: Control outputs $C_L = 80$ pF; ROM Expand Bus outputs $C_L = 150$ pF; System Bus outputs $C_L = 100$ pF; $V_{OUT}$ & INTENS outputs $C_L = 50$ pF; $V_{CAL} = 18$ MHz; $V_{CAL} = 100$ pF; $V_{OUT} = 12$ 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). <sup>\*\*1</sup> Dot time is 55 ns. | Capacit | Capacitance TA = 25°C, VCC = VSS = 0V | | |---------|---------------------------------------|-----------------| | Symbol | Parameter | Test Conditions | | _ | | | | Symbol | Parameter | Test Conditions | Min | Max | Units | |--------|-------------------|------------------------------------------------------|-----|-----|-------| | CIN | Input Capacitance | F <sub>C</sub> = 1 MHz (Note 5) | | 10 | pF | | Cout | Output and Reset | Unmeasured Pins Returned to V <sub>SS</sub> (Note 5) | | 20 | ρF | # **AC Electrical Characteristics in CPU Cycle Time** CPU AND ROM EXPAND BUS TIMING (FOR REFERENCE ONLY) | Symbol | Paramete | r | Тур | |------------------|--------------------------|----------------------------|-------------------------------------------------------------------------------| | tLL | ALE Pulse Width | | 14 t <sub>CY/60</sub> | | t <sub>AL</sub> | Address Setup to ALE | | 8 t <sub>CY/60</sub> | | t <sub>LA</sub> | Address Hold from ALE | | 6 t <sub>CY/60</sub> | | tcc | Control Pulse Width | PSEN<br>RD | 24 t <sub>CY/60</sub><br>36 t <sub>CY/60</sub> | | tcy | CPU Cycle Time | | $60 t_{CY/60} = 15/f_{CPU} = \frac{15}{f_{XTAL} \div 1 \text{ or } \div 1.5}$ | | t <sub>DR</sub> | Data Hold | | -2 t <sub>CY/60</sub> | | t <sub>RD</sub> | Control Pulse to Data In | PSEN<br>RD | 18 t <sub>CY/60</sub><br>30 t <sub>CY/60</sub> | | t <sub>AD</sub> | Address Setup to Data I | n | 32 t <sub>CY/60</sub> | | t <sub>AFC</sub> | Address Float to | PSEN<br>RD | 2 t <sub>CY/80</sub><br>2 t <sub>CY/60</sub> | | t <sub>CAF</sub> | PSEN to Address Float | | 0 t <sub>CY/60</sub> | | <sup>t</sup> DAL | 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 from ALE | RE0-7<br>RE8-12 | 2 tCY/60<br>6 tCY/60 | # SYSTEM BUS TIMING (FOR REFERENCE ONLY) | Symbol | Parameter | Tic | ks | |------------------|---------------------------|-------------------------------|----------------------------------------| | | | Min | Max | | t <sub>EL</sub> | RAM ALE Low Time | 14 t <sub>CY/60</sub> - 42 ns | | | t <sub>EH</sub> | RAM ALE High Time | 6 t <sub>CY/60</sub> - 25 ns | | | tas | Address Setup to RAM ALE | 4 t <sub>CY/60</sub> - 60 ns | ****** | | t <sub>AH</sub> | Address Hold from RAM ALE | 2 t <sub>CY/60</sub> - 40 ns | ······································ | | tRCY | Read or Write Cycle Time | | | | t <sub>RR</sub> | RAM RD Width | 12 t <sub>CY/60</sub> - 40 ns | - | | t <sub>AR</sub> | Address Setup to RAM RD | 6 t <sub>CY/60</sub> - 45 ns | | | t <sub>RRD</sub> | Data Access from RAM RD | | 10 t <sub>CY/60</sub> - 70 ns | | t <sub>RDR</sub> | Data Hold from RAM RD | | 01700 | | twFi | FIFO In Clock Width | 12 t <sub>CY/60</sub> - 40 ns | | | tww | RAM WR Strobe Width | 8 t <sub>CY/60</sub> - 27 ns | · | | t <sub>AW</sub> | Address Setup to RAM WR | 10 t <sub>CY/60</sub> - 90 ns | | | t <sub>DW</sub> | Data Setup to RAM WR | 2 t <sub>CY/60</sub> - 30 ns | | | t <sub>WD</sub> | Data Hold from RAM WR | 2 t <sub>CY/60</sub> - 20 ns | · · · · · · · · · · · · · · · · · · · | \*Remain I/O OUTPUT if External ROM not used. \*\*I/O Data input or 2nd ROM byte of 2 byte instruction. Otherwise remain I/O OUTPUT. TL/DD/5526-6 Scan Count Clear Timing For external character generation this edge is used to clock CLEAR into scan line counter. The edge must come before Scan Count Clear goes away, but not before the video controller has brought in all necessary display information for the last scan line. | 1.0 I | Functional Pin Descriptions | | |--------------|--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------| | | PPLIES | | | Pin | Name | Function | | 48 | V <sub>CC</sub> — Power | 5V ± 10% | | 24 | V <sub>SS</sub> — Ground Reference | | | 1.2 IN | PUT SIGNALS | | | 23, 22<br>29 | XTAL1, XTAL2 — Crystal 1, 2:<br>EA — External Access: | Crystal connections for clock oscillator (3–18 MHz). Pull HIGH $(V_{IH_2})$ | | 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). | | | TPUT SIGNALS | brives receiver section of OART (true data). | | 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 | | | | on the falling edge of ALE. Port output data may be latched on the rising 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. PSEN is idle (high) when | | 31 | RD — Read Port Data: | the CPU fetches from internal ROM. | | 31 | nd — Read Port Data: | Accept Port input data on ROM Expand Bus RE0-RE7 while low. ROM 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 | | | | and the falling edge is controlled by the Horizontal Sync End Register. HS is disabled (low) if bit 5 of the Video Control Register = 0. | | 27 | VS — Vertical Sync Output: | The falling edge of VS is controlled by the Vertical Sync Begin Register | | | | and the rising edge is controlled by the Vertical Sync End Register. $\overline{VS}$ is 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 | | 25 | INTENS/FO CLK | Video Control Register = 0. (Shared pin) INTENS Signal under attribute control may be used to switch | | | | the bistable brightness of display characters. | | | | FIFO Out Clock may be used to clock data from an external FIFO in<br>synchronism with data from the internal FIFO. | | | | Both CANNOT be used simultaneously. | | 17 | VID CLK/FI CLK — Video Dot Clock Out/<br>FIFO IN CLOCK | (Shared pin) The rising edge of the Video Dot Clock may be used to clock the data out of the video output pin. FIFO In Clock may be used to clock | | | | data from an extended attribute RAM into an external FIFO in | | | | synchronism with the data loaded into the internal FIFO. | | | | 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 | | | | falling edge of RAM ALE. Only operational when Display RAM accesses | | | | 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 | | 1.4 BUS | s—1/0 | rising edge of RAM WR. | | 1-8 | SB0-SB7 — System Bus 0-7: | Display PAM address is subsubushile DAMA ALE in bight and and | | | oso osi oyalam busu-1. | Display RAM address is output while RAM ALE is high and may be latched on the falling edge of RAM ALE. System Bus accepts data input | | 9-16 | SB8-SB15 — System Bus 8-15: | while RAM RD is low and outputs data while RAM WR is low. 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 PSEN is low. Enable I/O port | | | | input data to the Bus when $\overline{\text{RD}}$ is low. Use the rising edge of ALE to latch port output data. | | | | | | 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, LP, SC CLR, and HOLD signals. | | 37 | INTR — Interrupt: RE10 | An active low input that interrupts the processor if the external interrupt is enabled. Because it shares a pin with RE10, INTR may be driven directly only if no external ROM is used (EA is low). Otherwise must be driven through a 3.9k resistor.* | | 38 | □P — Light Pen Interrupt: RE9 | An active low input that interrupts the processor if internal interrupts are enabled and bit 5 in the Interrupt Mask Register is set. Because it shares a pin with RE9, LP may be driven directly only if EA is low. Otherwise, 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 Hold mode the System Bus will be in a high impedance state. The Hold mode is granted at the beginning of the next vertical retrace. Because it shares a pin with RE8, HOLD may be driven directly only if EA is low. 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. | <sup>\*</sup>Unused control inputs must be terminated # 2.0 Functional Description The CPU of the NS405 is patterned after the 8048 single chip microcomputer (see *Figure 1*). ### 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. TL/DD/5526~9 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). 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. FIGURE 4. Program Memory Map # 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). 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. | POINTER | LOCATION | | | | | | | | | | | |--------------|----------|---|-----|-----|---|---|-----|----|-----|---|---| | | 9 | | 2 | C8- | ı | | | -7 | 5W3 | P | | | 000 | 8 | | 1-3 | PC | | | 4-7 | PC | | | | | TL (DD (550) | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 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.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 ### 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. FIGURE 7. Timer Clock Generation ### 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: TI /DD/5526-16 Note: The interrupt flags indicated by an asterisk (\*) are cleared when the Interrupt Register is read. ### FIGURE 8. Internal Interrupt Register ### Bit O 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 TL/DD/5526-15 ### 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$ 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 TL/DD/5526-18 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-19 FIGURE 12a. TMP Oscillator TI /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. # PEM LIGHT PEN DETECTION CHARACTER GENERATOR CHARACTER GENERATOR CHARACTER GENERATOR ATTRIBUTE VIDEO OUTPUT GRAPHICS CONTROLLER VIDEO OUTPUT PIXEL GRAPHICS TL/DD/5526-21 Whether a status section is used or not, upon accessing all of the data necessary to display a field, the video RAM pointer is reset to HOME in preparation for the display of a new field. ### 2.2.3 Table Lookup Mode The CRSR (transparent to the user) is a pointer to the address of the first character in a display row. It is required because each time a scan line is displayed, all display characters in the row must be accessed anew. Since a row is made up of a number of scan lines, we must recover the address of the first character in the row for each scan in the row. After a row is done, the CRSR is normally advanced to point to the first character in the next row. In table look-up mode the starting memory location of the next row is loaded into the CRSR from the HOME register at the end of each row. The HOME register was presumably updated by the CPU since the last end of row. A CRSR load also generates the internal End of Row interrupt which the CPU will use as a signal to reload HOME. Finally, reloading HOME will clear out the End of Row interrupt. If the status section feature is used, upon reaching the begin status row location the CRSR will be loaded with SROW instead of HOME for that row. After which CRSR will revert back to load from HOME for the remaining rows on the screen. ### 2.3 SYSTEM CONTROL REGISTER Through the System Control Register (SCR) the user specifies several important chip operational conditions. It is an 8-bit write only register which is loaded from the CPU accumulator. TL/DD/5526-22 \*Bit 0 is set to 1 by RESET and bit 7 is set to 0 by RESET. # FIGURE 13. System Control Register # 2.4 VIDEO CONTROL REGISTER Through the Video Control Register (VCR) the user specifies several video display features to the chip. It is an 8-bit write only register which is loaded from the CPU accumulator. 7 TL/DD/5526-23 \_ .\_\_ .\_\_ \*Bit 5 is set to 0 by RESET. FIGURE 14. Video Control Register # 2.5 CRT REFRESH LOGIC All video timing and clocking signals are derived from a series of counters and comparators called the Video Timing Chain. The chain is driven by the dot/crystal clock and ultimately divides down to the very slow blink clock, (Figure 15). By having the program initialize the registers in the chain a user may specify all aspects of video generation. The chain also controls the size and placement of the cursor and underline attribute within a character cell as well as the cell partitioning for block graphics display. All totaled, the chain consists of 14 wire only registers. They are loaded indirectly by using the Timing Chain Pointer (TCP), a 4-bit pointer to registers in the chain, and the MOV @TCP, A instruction. FIGURE 15. TMP Video Timing Chain ### 2.5.1 TMP Timing Chain Registers ### TCP ### **Horizontal Timing** - 0 Horizontal Length Register HLR 7 bits - Total number of character cells in a horizontal scan and retrace. - Enter desired count 1 - Horizontal Blank Begin Register HBR 7 bits (Characters/Row) - Character position in horizontal scan after which horizontal blanking begins. - Enter desired number of displayed characters/row 1. - 2 Horizontal Sync Begin Register HSBR 7 bits - Character position in horizontal scan after which horizontal sync begins (rising edge), HSBR ≤ HLR. - Enter desired count + 2. # 2.5.1 TMP Timing Chain Registers (Continued) | 2.5.1 TN | IP 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 ≤ 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 | Extra Scans/Frame — ES/F 4 bits | | Low | Number of extra scans to be added to a frame if desired. The desired are the second of s | | Nibble | — Enter desired number of extra scans -1. | | | <ul> <li>To get no extra scans make ES/F = CSHR. ES/F must be ≤ CSHR.</li> </ul> | | TCP | 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) | | | <ul> <li>Row position in vertical scan after which vertical blanking begins, VBR &lt; VLR.</li> </ul> | | | <ul> <li>Enter desired number of displayed rows — 1.</li> </ul> | | 7 | Vertical Sync Begin Register — VSBR 4 bits | | High<br>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> | | | Enter desired scan line position - 1. | | | 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> | | | — Enter desired row position — 1. | | TCP | Cursor and Graphics Control | | 9 | Blink Rate 5 bits | | Upper<br>5 Bits | <ul> <li>Divider driven by the vertical sync frequency to yield the slow cursor, character and real-time blink rates.</li> <li>Enter desired divisor — 1.</li> </ul> | | 9 | Blink Duty Cycle 3 bits | | Lower | - 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> | | | <ul> <li>Enter desired scan count - 1.</li> </ul> | | 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<br/>must be ≤ CSHR.</li> </ul> | | 13 | Cursor Size Register — CSR 8 bits (see Figures 16a, b, c) | - Defines the beginning (upper nibble) and ending (lower nibble) scan lines for the cursor. Values must be $\leq$ CSHR. FIGURE 16. Underline and Cursor Register Operation 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 cursor size register or between the upper nibble and lower nibble values of the cursor size register. To use the cursor as a pointer without displaying it, set the lower nibble of the cursor size register to a value less than CSHR and the upper nibble 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 = 101. We will display 25 rows so VBR = 1011 = 101. We will display 25 rows so VBR = 1011 = 101. Vertical sync will start at the beginning of the fourth scan TL/DD/5526-26 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 no the video dot stream to affect display characters on either an individual or global basis. The eight attributes along with their con- TL/DD/5526-27 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. FIGURE 19. TMP Attribute Processing TL/DD/5526-28 ### 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 genera- tor 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 High Bottom: 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.) FIGURE 20. Character Cell Format ### 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. FIGURE 21. External Character Set Implementation TL/DD/5526-30 ### 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 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-3 # 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. 7 The Graphics Column Register — 8 bits (GCR) controls vertical partitioning through bit patterns as follows: (See *Figure 24*) | ſ | 7 | • | 5 | 4 | | 2 | 1 | ٠ | GCR | |---|---|---|---|---|---|---|---|---|---------------------| | I | - | Ł | L | | R | X | X | X | OOT FIELD WIDTH | | 1 | ī | _ | ٦ | R | R | 8 | X | X | | | ١ | ٦ | ٦ | | | | | | | 4-8 DOT FIELD WIDTH | | | L | ı | ٦ | - | | R | R | R | → 9 DOT FIELD WIDTH | TL/DD/5528-33 FIGURE 24. Block Graphics Column Partitioning # FIGURE 24.1a Block Graphics Example 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 TL/DD/5526-34 FIGURE 25. Example Pixel Graphics 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/5528-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. TL/DD/5526-37 \*Bit 5 set to 0 by RESET. FIGURE 28. UART Control Register # 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. TL/DD/5526-39 FIGURE 30. UART BAUD Clock Divider Registers | IABLE I. Pres | scale 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) | TABLE III. Daud nate DIV | isors (1.6432 Minz 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 | FIGURE 29. UART BAUD Clock Generation 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). TL/DD/5526-40 FIGURE 31. UART Multiplex Register 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 RESET (32) pin is held at a logic low (< 0.8V) for at least five CPU cycle times. This pre-supposes that the $V_{\rm CC}$ 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_{\rm CC}$ 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 During RESET a number of internal registers are initialized as follows: ### 4.1 CPU ``` CPU Clock divide = 1.5 (SCR bit 0 = 1) ``` Shared VIDCLK/FICLK = 0 (SCR bit 7 = 0, FICLK gated to external pin) Program Counter = 0 Stack Pointer = 0 Program Memory Bank = 0 RAM Register Bank = 0 Timer Stopped Instruction Register cleared F0 and F1 cleared ### **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 IN TEST MODE ONLY 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 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- 15 will act as outputs (any of which may be either high or low). Note that bit 4 of the SCR may 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 (RAMWR) 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 (VS) 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 $(V_{HH_2})$ ) # 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 Count Clear signal is output at rising edge of ALE. Pin 37 (RE10/INTR) Pin 38 (RE9/LPEN) 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. auge of ALL. 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. FIGURE 34. TMP ROM Expand BUS TL/DD/5526-42 TL/DD/5526-43 # **6.0 TMP BUS Interfacing** (Continued) FIGURE 35. TMP System Bus # TMP Registers (Excluding Timing Chain Registers) | TMP Regis | ters | Asa | ociated Intructions | |-------------------------|--------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | CPU SECTION | | | A<br>#data<br>Rr<br>@Rr | = Accumulator — 8 bits = data immediate = Register = Register pointed to by R0 or R1 | ADD A,Rr ADD A,#data ADD A,@Rr ADDC A, #Rr ADDC A, #data ADDC A,@Rr ANL A,@Rr ANL A,Rr ANL A,@Rr CLR A CPL A DAA DEC A DEC Rr INC A INC Rr | MOV A,Rr MOV A,@Rr MOV A,#data MOV Rr,A MOV Rr,A MOV @Rr,A MOV @Rr,A MOVP A,@A MOVP3 A,@A RL A, RC A RR A RRC A ORL A,Rr ORL A,#data XCH A,Rr XCH A,@Rr XRL A,@Rr XRL A,,#data JBn addr JNZ addr JZ addr DJNZ Rr,addr RLC A RR A RRC A ORL A,Rr ORL A,Rr ORL A,#data | | *HACC | = High Accumulator — 8 bits | INC @Rr<br>*MOV A.HACC | SWAP A<br>*MOV HACC,A | | C | = Carry Bit | CLR C CPL C | JNC addr JC addr | | *LONG R0 | • | *DECL R0<br>*MOVL R0,A | *INCL R0 | | *LONG R1 | = Register Pair R1, RB | *DECL R1<br>*MOVL R1,A | *INCL R1 *MOVL A,R1 *MOVX A,@R1 *MOVX @R1,/ | | Т | = Timer — 8 bits | MOV A,T<br>STRT T | MOV T,A STOP T *JNTF addr JTF addr | | F0 | =Flag 0 | CLR F0 CPL F0 | JF0 addr *JNF0 addr | | F1 | = Flag 1 | CLR F1 CPL F1 | JF1 addr *JNF1 addr | | INTR | = Interrupt Register — 8 bits | MOV A,INTR<br>*DIS II<br>EN XI | JNXI addr JXI addr<br>DIS XI *EN II | # TMP Registers (Excluding Timing Chain Registers) (Continued) # TMP Registers Associated Instructions PSW = Program Status Word --- 8 bits MOV A,PSW MOV PSW,A PORT = 8 bit I/O Port ANL PORT, # data IN PORT ORL PORT,#data OUT PORT Miscellaneous Instructions CALL addr JMP addr JMPP @A NOP RET RETR # **VIDEO MANAGEMENT** # Associated Instructions = System Control Register — 8 bits \*MOV SCR.A SCR = System Control Register - 8 bits \*MOV VCR.A = Video Control Register - 8 bits VCR \*MOV A.HOME \*MOV HOME.A = Home Address Register - 16 bits HOME \*MOVX A,@CURS = Cursor Address Register --- 16 bits \*DEC CURS \*INC CURS CURS \*MOVX @CURS.A \*MOV CURS,A \*MOV A,CURS BEGD = Beginning of Display RAM Register — 16 bits \*MOV BEGD,A ENDD = End of Display RAM Register — 16 bits \*MOV ENDD,A SROW = Status Row Register — 16 bits \*MOV SROW,A AL0 = Attribute Latch 0 — 8 bits \*MOV AL0,A \*MOV AL1,A \*MOV AL1,A # **UART CONTROL** \*MOV PSR.A = Prescale Register (UART) - 8 bits PSR \*MOV BAUD,A BAUD = Baud Rate Select Register --- 8 bits \*MOV UCR,A = UART Control Register - 8 bits UCR = UART Multiplex Register — 8 bits \*MOV UMX,A UMX \*MOV A,STAT = Status Latch (UART) - 6 bits STAT \*IN RCVR **RCVR** = UART Receive Buffer - 8 bits \*OUT XMTR = UART Transmit Buffer - 8 bits **XMTR** \*MOV TCP,A TCP = Timing Chain Pointer \*MOV @TCP.A @TCP = Register Pointed to by TCP # **Symbol Definitions** | Symbol | Definition | |--------|-------------------------------------| | AC | Auxiliary Carry Flag | | addr | Program Memory Address | | ь | 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 | | | designated register | | ← | Replaced by | <sup>\*</sup>New instruction added to 8048 subset. | Mnemonic | Machine Code | Function | Description | Cycles | Rytes | | | Flags | | |------------------|------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|--------|-------|---|----|-------|------| | Milemonic | macrime code | runction | Description | Cycles | Dytes | Ċ | AC | HACC | F0 F | | ADD A, Rr | 0 1 1 0 1 r r r | $(A) \leftarrow (A) + (Rr)$ for $r = 0 - 7$ | Add contents of designated register to the Accumulator (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 specified data to the Accumulator (8-bit operation) | 2 | 2 | * | * | * | | | ADD A, @ Rr | 0 1 1 0 0 0 0 r | (A) $\leftarrow$ (A) + ((Rr)) for $r = 0 - 1$ | Add indirect the contents of data memory pointed to by Rr to the Accumulator (8-bit operation) | 1 | 1 | * | • | * | | | ADDC A, Rr | 0 1 1 1 1 rrr | $(A) \leftarrow (A) + (C) + (Rr)$ for $r = 0 - 7$ | Add with carry the contents of the designated register to the Accumulator (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 carry the specified data to the Accumulator (8-bit operation) | 2 | 2 | * | • | • | | | ADDC A, @ Rr | 0 1 1 1 0 0 0 r | (A) $\leftarrow$ (A) + (C) + ((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 | 0 1 0 1 1 rrr | (A) ← (A) AND (Rr) for 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 | 0 1 0 1 0 0 0 r | (A) ← (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 immediate specified data with output port (8-bit operation) | 2 | 2 | | | | | | CALL addr | a10 a9 a8 1 0 1 0 0<br>a7 a6 a5 a4 a3 a2 a1 a6 | $((SP)) \leftarrow (PC0-12)$<br>$O((SP)) \leftarrow (PSW3-7)$<br>$(SP) \leftarrow (SP) + 1$<br>$(PC8-10) \leftarrow addr 8-10$<br>$(PC0-7) \leftarrow addr 0-7$<br>$(PC11-12 \leftarrow DBF 0, 1)$ | Call designated subroutine | 2 | 2 | | | | | | Instruct | ioi | n S | Set | t (c | Соп | itin | ued | ) | | | | | | _ | | | | _ | |---------------|-----------------|----------|----------|------|-----|----------|----------|-------------|---------|-----------------------------------------------------|--------------------------------------------------------------------------|-----|---------------|--------------|----------|----------|--------------|---------| | Mnemonic | Machine Code Fu | | | | | | Function | Description | Cycles | Bytes | cl | AC | Flags<br>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 | ٠ | | | | L | | CLR F0 | | | 0 | | | | _ | _ | - | (FO) ← 0 | Clear Flag 0 | 1 | 1 | L | <u> </u> | | • | L | | CLR F1 | | | 1 | _ | _ | | | | -+ | (F1) ← 0 | Clear Flag 1 | 1 _ | 1 | L | | | <u> </u> | * | | CPL A | | | 1 | _ | _ | | _ | | - | (A) ← NOT (A) | Complement the contents of the Accumulator (8-bit operation) | 1 | 1 | | | | | | | CPL C | 1 | 0 | 1 | 0 | ( | ) | 1 | 1 | 1 | (C) ← NOT (C) | Complement carry bit | 1 | 1 | * | | | | L | | CPL F0 | 1 | 0 | 0 | 1 | ( | <u> </u> | 1 | 0 | 1 | (F0) ← NOT (F0) | Complement Flag 0 | 1 | 1 | L | _ | <u> </u> | <u> </u> | Ļ | | CPL F1 | 1 | 0 | 1 | 1 | _ | 0 | 1 | 0 | _ | (F1) ← NOT (F1) | Complement Flag 1 | 1 | 1 | ┸ | | <u> </u> | ┺ | Ľ | | DA A | 0 | 1 | 0 | 1 | ( | 0 | 1 | 1 | 1 | | Decimal Adjust the contents of the Accumulator (8-bit operation) | 1 | 1 | • | • | | | | | DEC A | 0 | 0 | 0 | O | ) | 0 | 1 | 1 | 1 | (HACC, A) ← (HACC,<br>A) - 1 | Decrement by 1 the contents of HACC/<br>ACC | 1 | 1 | | | • | | | | DEC CURS | 0 | 0 | 0 | C | ) | 1 | 0 | 1 | 0 | (CURS) ← (CURS) - 1 | Decrement by 1 the contents of the Cursor Address Register | 1 | 1 | | | | | | | DEC Rr | 1 | 1 | 0 | ( | ) | 1 | r | r | r | (Rr) ← (Rr) − 1 | Decrement by 1 the contents of the designated register (8-bit operation) | 1 | 1 | | | | | | | DECL Rr | 0 | 0 | 0 | ( | ) | 1 | 0 | 0 | r | (Rr) ← (Rr) − 1 for<br>r = 0 − 1 | Decrement by 1 the contents of the designated 16-bit register pair | 1 | 1 | | | | | | | DIS II | 0 | 0 | 1 | | 1 | 0 | 1 | 0 | 1 | | Disable internal interrupts | 1 | 1 | $\downarrow$ | | | | $\perp$ | | DIS XI | 0 | 0 | 0 | , | 1 | 0 | 1 | 0 | 1 | | Disable external interrupts | 1 | 1 | | | | $\downarrow$ | ] | | DJNZ Rr, addi | 1<br>a7 | 1<br>7 a | 1<br>6 a | 5 a | 0 | 1<br>a3 | r<br>a2 | r<br>a1 | r<br>a0 | $(Rr) \leftarrow (Rr) - 1 \text{ for}$<br>r = 0 - 7 | Decrement the<br>specified register | 2 | 2 | | | | | | 7-32 If (Rr) $\neq$ 0 do (PC0-7) 1 (HACC, A) ← (HACC, (CURS) ← (CURS) + 1 ← addr If (Rr) = 0 do (PC) ← PC + 2 A) + 1 and Jump if not zero address within page (8-bit decrement) Enable internal 1 1 1 1 1 1 to designated interrupts. interrupt. Enable external Increment by 1 the Increment by 1 the contents of the Cursor Address Register. contents of HACC/A. 0 0 1 0 0 1 0 1 0 0 0 0 0 1 0 1 0 0 1 1 1 0 1 0 0 0 0 1 0 1 1 EN II EN XI INC A INC CURS | Mnemonic | | | Mac | hina | · C | de | | | Function | Description | Cycles | Rytee | | | Flags | | | |------------|-----------|---------|-----------------|---------|---------|---------|---------|---------|-----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--------|-------|---|----|-------|----|----| | MITCHIOTIC | | | wac | | | ,,,, | | | Tunction | Description | Cycles | Dytes | С | AC | HACC | FO | F1 | | INC Rr | 0 | 0 | 0 | 1 | 1 | r | r | r | $(Rr) \leftarrow (Rr) + 1 \text{ for }$<br>r = 0 - 7 | Increment by 1 the contents of the designated register (8-bit increment) | 1 | 1 | * | | | | | | INC @ Rr | 0 | 0 | 0 | 1 | 0 | 0 | 0 | r | $((Rr)) \leftarrow ((Rr)) + 1 \text{ 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 | г | $(Rr) \leftarrow (Rr) + 1 \text{ for }$<br>r = 0 - 1 | Increment by 1 the contents of the designated 16-bit 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 | | | b0<br>a5 | | | 0<br>a2 | | 0<br>a0 | (PC0-7) ← addr if<br>(b) = 1<br>(PC) ← (PC) + 2 if<br>(b) = 0 for b = 0 - 7 | Jump to specified address within page if Accumulator bit is set | 2 | 2 | | | | | | | JC addr | 1<br>a7 | 1<br>a6 | 1<br><b>a</b> 5 | - | - | 1<br>a2 | | 0<br>a0 | (PC0-7) ← addr if<br>C = 1<br>(PC) ← (PC) + 2 if<br>C = 0 | Jump to specified address within page if Carry flag is set | 2 | 2 | | | | | | | JF0 addr | 1<br>a7 | 0<br>a6 | 0<br><b>a</b> 5 | 1<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7) ← addr if<br>F0 = 1<br>(PC) ← (PC) + 2 if<br>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>a4 | | 1<br>a2 | | 0<br>a0 | (PC0-7) ← addr if<br>F1 = 1<br>(PC) ← (PC) + 2 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 | 0<br>a1 | 0<br>a0 | (PC8-10) ← addr 8-10<br>(PC0-7) ← addr 0-7<br>(PC11-12) ← DBF 0, 1 | 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 | 1<br>a5 | 0<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7) ← addr<br>if C = 0<br>(PC) ← (PC) + 2<br>if C = 1 | Jump within page to<br>specified address if<br>Carry flag is 0 | 2 | 2 | | | | | | | 1 | | | 1 | | n | | Flag | 3 | | |-------------|--------------------------------------------|-------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|--------|-------|----|-------|----|----| | Mnemonic | Machine Code | Function | Description | Cycles | Bytes | CA | C HAC | FO | F1 | | INF0 addr | 1 0 0 0 0 1 1 0<br>a7 a6 a5 a4 a3 a2 a1 a0 | F0 = 0 | Jump within page to<br>specified address if<br>F0 is 0 | 2 | 2 | | | | | | JNF1 addr | 0 1 1 0 0 1 1 0<br>a7 a6 a5 a4 a3 a2 a1 a0 | ( , | Jump within page to<br>specified address if<br>F1 is 0 | 2 | 2 | | | | | | JNTF addr | 0 0 0 0 0 1 1 0<br>a7 a6 a5 a4 a3 a2 a1 a0 | $(PC0-7) \leftarrow addr if$ $TF = 0$ $(PC) \leftarrow (PC) + 2 if$ $TF = 1, (TF) \leftarrow 0$ | 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 0 1 0 0 1 1 0<br>a7 a6 a5 a4 a3 a2 a1 a0 | | Jump within page to<br>specified address if<br>External Interrupt pin<br>is LOW | 2 | 2 | | | | | | JNZ addr | 1 1 0 1 0 1 1 0<br>a7 a6 a5 a4 a3 a2 a1 a0 | | Jump within page to<br>specified address if<br>Accumulator is not 0 | 2 | 2 | | | | | | JTF addr | 0 0 0 1 0 1 1 0<br>a7 a6 a5 a4 a3 a2 a1 a0 | $(PC0-7) \leftarrow addr if$ $TF = 1, (TF) \leftarrow 0$ $(PC) \leftarrow (PC) + 2 if$ $TF = 0$ | 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 0 1 1 0 1 1 0<br>a7 a6 a5 a4 a3 a2 a1 a | | Jump within page to<br>specified address if<br>External Interrupt pin<br>is HIGH | 2 | 2 | | | | | | JZ addr | 1 1 0 0 0 1 1 0<br>a7 a6 a5 a4 a3 a2 a1 a | | Jump within page to<br>specified address if<br>Accumulator is 0 | 2 | 2 | | | | | | MOV A, CURS | 1 0 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 ( | (A) ← (HACC) | Copy contents of the<br>High Accumulator<br>into the Low<br>Accumulator (8-bit<br>transfer) | 1 | 1 | | | | | | MOV A, HOME | 1001101 | ) (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 0 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 | | | Mac | hin | e C | ode | • | | Function | Description | Cycles | Bytes | | | Flags | _ | _ | |---------------|---|---|-----|---------|-----|-----|---|---|---------------------------------------|----------------------------------------------------------------------------------------------------------------------|---------|-------|---|----|-------|----|----| | | | | | | | | | | | | , , , , | _, | С | AC | HACC | F0 | F1 | | 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 | (A) ← (PSW) | Copy contents of the<br>Program Status word<br>into the Accumulator<br>(8-bit transfer) | 1 | 1 | | | | | | | MOV A, Rr | 1 | 1 | 1 | 1 | 1 | r | r | r | $(A) \leftarrow (Rr)$ for $r = 0 - 7$ | Copy the contents of<br>the designated<br>Register into the<br>Accumulator (8-bit<br>transfer) | | | | | | | | | MOV A, STAT | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | (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 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | (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 contents of data memory pointed to by Rr into the Accumulator (8-bit transfer) | 1 | 1 | | | | | | | MOV A, # data | | | | 0<br>d4 | | | | | (A) ← data | 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 | (AL0) ← (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 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | (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 | | | | | | | | | | _ | _ | _ | | | - 1 | F allan | Description | Cycles | Rytes | | | Flags | | _ | |-------------|---|---|-----|------|----|----|---|-----|---------------------------------------|-------------------------------------------------------------------------------------------------|--------|----------|---|----|-------|----|----| | Mnemonic | | M | ach | ilne | Co | de | | l | Function | Description | Cycles | <b>-</b> | С | AC | HACC | F0 | F1 | | MOV CURS, A | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 ( | CURS) ← (HACC/A) | Copy the contents of HACC/A into the Cursor Address Register (16-bit 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) \leftarrow (A)$ for $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 | (T) ← (A) | 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 | | | Mac | :hin | e C | ode | | | Function | Description | Cycles | Bytes | | | Flags | | | |------------------|---|---|-----|--------|-----|-----|---|---|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--------|-------|---|----|-------|----|----| | | | | | ,,,,,, | | - | | | T unouon | | 0,0.00 | , | С | AC | HACC | FO | F1 | | MOV UCR, A | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | (UCR) ← (A) | Copy the contents of<br>the Accumulator into<br>the UART Control<br>Register (8-bit transfer) | 1 | 1 | | | | | | | MOV VCR, A | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | (VCR) ← (A) | Copy the contents of<br>the Accumulator into<br>the Video Control<br>Register (8-bit transfer) | 1 | 1 | | | | | | | MOV VINT, A | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | (VINT) ← (A) | Copy the contents of<br>the Accumulator into<br>the Vertical Interrupt<br>Register | 1 | 1 | | | | | | | MOV Rr, # data | | | | | | | | | (Rr) ← data for<br>r = 0 - 7 | Load immediate the<br>specified data into the<br>designated register (8-<br>bit load) | 2 | 2 | | | | | | | MOV @ Rr, A | 1 | 0 | 1 | 0 | 0 | 0 | 0 | r | ( (Rr) ) ← (A) for<br>r = 0 − 1 | Copy indirect the contents of the Accumulator into the data memory location pointed to by Rr (8-bit transfer) | 1 | 1 | | | | | | | MOV @ Rr, # data | | | | | | | | | ((Rr)) ← data for<br>r = 0 − 1 | Load indirect the specified immediate data into the data memory location pointed to by Rr (8-bit load) | 2 | 2 | | | | | | | MOV @ TCP, A | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | ((TCP)) ← (A)<br>(TCP) ← (TCP) + 1 | Copy indirect the contents of the Accumulator into the Timing Chain Register pointed to by TCP. Contents of TCP incremented by 1 | 1 | 1 | | | | | | | MOV UMX, A | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | (UMX) ← (A) | Copy the contents of<br>the Accumulator into<br>the UART Multiplex<br>Register (8-bit transfer) | 1 | 1 | | | | | | | MOVL A, R0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | (HACC/A) ← (RA, R0) | Copy the contents of RA, R0 into HACC/A (16-bit transfer) | 1 | 1 | | | • | | | | MOVL A, R1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | (HACC/A) ← (RB, R1) | Copy the contents of RB, R1 into HACC/A (16-bit transfer) | 1 | 1 | | | * | | | | MOVL RO, A | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | (RA, R0) ← (HACC/A) | Copy the contents of HACC/A into RA, R0 (16-bit transfer) | 1 | 1 | | | | | | | MOVL R1, A | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | (RB, R1) ← (HACC/A) | Copy the contents of HACC/A into RB, R1 (16-bit transfer) | 1 | 1 | | | | | | | Mnemonic | | | laci | hine | · Cr | hde | | ١ | Function | Description | Cycles | Bytes | L | _ | Flags | | |----------------|---|---|------|-------|------|------|---|---|------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|---|----|-------|-----| | Milelionic | | | iaci | urite | | ,,,, | | | | • | | | С | AC | HACC | FOF | | MOVPA, @ A | 1 | 0 | 1 | 1 | 0 | 0 | 1 | L | (PC0-7) ← (A)<br>(A) ← ( (PC) )<br>(PC0-7) ← (old PC0-7)<br>+ 1 | Replace low 8 bits of PC with A. Load indirect within page the contents of the memory location pointed to by new PC into Accumulator. Restore PC with old value plus 1. Operates in all memory banks. | 2 | 1 | | | | | | MOVP3 A, @ A | 1 | 1 | 1 | 1 | 0 | 0 | 1 | | (PC0-7) ← (A)<br>(PC8-10) ← 011<br>(A) ← ((PC))<br>(PC) ← (old PC) + 1 | Replace low 8 bits of PC with A. Next 3 bits replaced with 011. Load indirect within page 3 the contents of the memory location pointed to by new PC into the Accumulator. Restore PC with old value plus 1. Operates in all memory banks. | | 1 | | | | | | MOVX A, @ CURS | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | (HACC/A) ← ((CURS)) | Copy indirect the contents of display memory as pointed to by CURS into HACC/A (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 contents of HACC/A into the display memory location as pointed to by CURS (16-bit transfer) | Min. 2 | 1 | | | | | | MOVX @ R0, A | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ((RA, R0)) ← (HACC// | A) Copy indirect the contents of HACC/A into the display memory location as pointed to by RA, R0 (16-bit transfer) | Min. | 2 1 | | | | | | 7 | |---| | 1 | | | | | | | | | | | | | <b>0</b> 1 | <b>D</b> | | | Flags | | |------------------|---|---|------|-----|-----|---------|---|---|---------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------|---|----|-------|------| | Mnemonic | | , | Vlac | hin | e C | ode | • | | Function | Description | Cycles | Bytes | С | AC | HACC | F0 F | | MOVX @ R1, A | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | ( (RB, R1) ) ← (HACC/A) | Copy indirect the contents of HACC/A into the display memory location pointed to by RB, R1 (16-bit transfer) | Min. 2 | 1 | | | | | | NOP | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | No Operation | 1 | 1 | | | | | | ORL A, Rr | 0 | 1 | 0 | 0 | 1 | r | r | r | (A) ← (A) OR (Rr) for<br>r = 0 - 7 | Logical OR contents of<br>designated register<br>with Accumulator (8-bit<br>transfer) | 1 | 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 contents of the data memory location pointed to by Rr with Accumulator (8-bit 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) | | 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 without restoring Program Status Word bits 5-7 | 2 | 1 | | | | | | RETR | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | $(SP) \leftarrow (SP) - 1$<br>$(PC0-12) \leftarrow ((SP))$<br>$(PSW 3-7) \leftarrow ((SP))$ | Return from<br>Subroutine restoring<br>Program Status Word<br>(use for all returns from<br>interrupts) | 2 | 1 | • | • | | | | RL A | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | $(A_{n + 1}) \leftarrow (A_n)$<br>for $n = 0 - 6$<br>$(A_0) \leftarrow (A_7)$ | Rotate Accumulator left by 1 bit without 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>$(A_0) \leftarrow (C)$<br>$(C) \leftarrow (A_7)$ | Rotate Accumulator left by 1 bit through carry | 1 | 1 | • | | | | | | | | | | | | | J | | Desertation | Cycles | Bytes | | | Flags | | |---------------|---|---|-----|-----|-----------|-----|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|--------|--------|----|--------------------|----------|----| | Mnemonic | | N | lac | hin | в Сс | ode | | - | Function | Description | Cycles | Dy les | С | AC | HACC | FO | | R A | 0 | 1 | 1 | 1 | 0 | 1 | 1 | | $(An) \leftarrow A_{n+1}$<br>for $n = 0 - 6$ | Rotate Accumulator right by 1 bit without carry | 1 | 1 | | | | | | RRC A | 0 | 1 | 1 | 0 | 0 | 1 | 1 | | $ \begin{aligned} &(An) \longleftarrow A_{n+1} \\ &\text{for } n = 0 - 6 \\ &(A7) \longleftarrow (C) \\ &(C) \longleftarrow (A0) \end{aligned} $ | Rotate Accumulator right by 1 bit through 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 | | L | | | | STOP T | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | | Stop Timer | 1 | 1 | ↓_ | ┺ | <u> </u> | ╀- | | STRT T | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | | Start Timer | 1 | 1 | L | $oldsymbol{\perp}$ | _ | ╀- | | SWAP A | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | (A4−A7) ←→ (A0−A3) | SWAP 4 bit nibbles in<br>Accumulator | 1 | 1 | | | | L | | XCH A, Rr | 0 | 0 | 1 | 0 | 1 | r | r | r | $(A) \longleftrightarrow (Rr)$ for $r = 0 - 7$ | Exchange the<br>Accumulator and<br>contents of designated<br>register (8-bit transfer) | | 1 | | | | | | XCH A, @ Rr | 0 | 0 | 1 | 0 | 0 | 0 | 0 | r | (A) ←→ ((Rr))<br>for r = 0 − 1 | Exchange indirect the contents of the Accumulator and the data memory location pointed to by Rr (8-bit transfer) | 1 | 1 | | | | | | XCHD A, @ Rr | 0 | 0 | 1 | 1 | 0 | 0 | 0 | r | $(A0-3) \longleftrightarrow ((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 | r | (A) $\leftarrow$ (A) XOR (Rr)<br>for $r = 0 - 7$ | Logical XOR contents<br>of designated register<br>with Accumulator (8-b<br>transfer) | | 1 | | | | | | XRL A, @ Rr | 1 | 1 | 0 | 1 | 0 | 0 | 0 | r | (A) ← (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 | | | | | 0<br>4 d3 | | | | (A) ← (A) XOR data | Logical XOR the immediate specified data with the Accumulator | 2 | 2 | | | | | | | | | | | | | | | SN | | | | | | _ | _ | |---|----------------------|----------------------|-------------------|-----------------------|---------------------|------------------|------|-------------------|---------------------|---------------------|---------------------|---------------------|---------------------|----------------------|---------------------|-------------------| | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | В | С | D | E | F | | 9 | 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 | | 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>11 | | 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>AL0,<br>A | MOV<br>AL1,<br>A | MOV<br>A,<br>VPEN | MOV<br>A,<br>HFEI | | 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 | | 6 | 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 | ADE<br>A,<br>R7 | | 7 | ADDC<br>A,<br>@R0 | ADDC<br>A,<br>@R1 | JB3 | ANL<br>PORT,<br>#data | CALL<br>(page<br>3) | STRT | 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 | ADD<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>(page<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 | MO'<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 | MO<br>R7<br>#da | | С | 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>(page<br>6) | SEL<br>MB1 | JNZ | MOV<br>PSW,<br>A | XRL<br>A,<br>R0 | 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 | XR<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 | RLA | DJNZ<br>R0 | DJNZ<br>R1 | DJNZ<br>R2 | DJNZ<br>R3 | DJNZ<br>R4 | DJNZ<br>R5 | DJNZ<br>R6 | DJN<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 | MO<br>A, | # Ordering Information order Part NUMBERS ROMiess NS405-A12N NS405-B12N NS405-B18N NS405-C12N 7-42