### Microprocessor Peripherals UPI- 41A/41AH/42/42AH User's Manual

October 1993

Order Number: 231318-006



| <b>MCS-48</b> | 8048 - 8049 |
|---------------|-------------|
| and           | 8041 - 8042 |
| <b>UPI-41</b> |             |

| Ceibo In-Circuit<br>Emulator Supporting<br>MCS-48 and UPI-41: | DS-48                                        |
|---------------------------------------------------------------|----------------------------------------------|
|                                                               | http://www.ceibo.com/eng/products/ds48.shtml |

Information in this document is provided in connection with Intel products. Intel assumes no liability whatsoever, including infringement of any patent or copyright, for sale and use of Intel products except as provided in Intel's Terms and Conditions of Sale for such products.

Intel retains the right to make changes to these specifications at any time, without notice. Microcomputer Products may have minor variations to this specification known as errata.

\*Other brands and names are the property of their respective owners.

†Since publication of documents referenced in this document, registration of the Pentium, OverDrive and iCOMP trademarks has been issued to Intel Corporation.

Contact your local Intel sales office or your distributor to obtain the latest specifications before placing your product order.

Copies of documents which have an ordering number and are referenced in this document, or other Intel literature, may be obtained from:

Intel Corporation P.O. Box 7641 Mt. Prospect, IL 60056-7641

or call 1-800-879-4683

COPYRIGHT © INTEL CORPORATION, 1996

## Microprocessor Peripherals UPI-41A/41AH/42/42AH User's Manual

#### CONTENTS

PAGE

| CHAPTER 1. INTRODUCTION                                  | 1 |
|----------------------------------------------------------|---|
| Interface Registers for Multiprocessor<br>Configurations | 3 |
| Powerful 8-Bit Processor                                 | 3 |
| Special Instruction Set Features                         | 4 |
| Preprogrammed UPI's                                      | 5 |
| Development Support                                      | 6 |
| UPI Development Support                                  | 6 |

### CHAPTER 2. FUNCTIONAL DESCRIPTION

| CONTENTS                                             | PAGE |
|------------------------------------------------------|------|
| Reset                                                | 19   |
| Data Bus Buffer                                      | 20   |
| System Interface                                     | 21   |
| Input/Output Interface                               | 22   |
| Ports 1 and 2                                        | 22   |
| Ports 4, 5, 6, and 7                                 | 23   |
| CHAPTER 3. INSTRUCTION SET                           | 26   |
| Instruction Set Description                          | 28   |
| Alphabetic Listing                                   | 30   |
| CHAPTER 4. SINGLE-STEP AND<br>PROGRAMMING POWER-DOWN | 50   |
| MODES                                                |      |
| •                                                    |      |
| External Access                                      | 55   |
| Power Down Mode<br>(UPI-41AH/42AH Only)              | 55   |
| CHAPTER 5. SYSTEM OPERATION .                        | 56   |
| Bus Interface                                        | 56   |
| Design Examples                                      | 57   |
| General Handshaking Protocol                         | 60   |
| CHAPTER 6. APPLICATIONS                              | 62   |
| Abstracts                                            | 62   |
|                                                      |      |

#### CHAPTER 1 INTRODUCTION

Accompanying the introduction of microprocessors such as the 8088, 8086, 80186 and 80286 there has been a rapid proliferation of intelligent peripheral devices. These special purpose peripherals extend CPU performance and flexibility in a number of important ways.

| 8255 (GPIO)       | Programmable Peripheral<br>Interface                               |
|-------------------|--------------------------------------------------------------------|
| 8251A(USART)      | Programmable<br>Communication Interface                            |
| 8253 (TIMER)      | Programmable Interval Timer                                        |
| 8257 (DMA)        | Programmable DMA Controller                                        |
| 8259              | Programmable Interrupt<br>Controller                               |
| 82077AA           | Programmable Floppy Disk<br>Controller                             |
| 8273 (SDLC)       | Programmable Synchronous<br>Data Link Controller                   |
| 8274              | Programmable Multiprotocol-<br>Serial Communications<br>Controller |
| 8275/8276 (CRT)   | Programmable CRT<br>Controllers                                    |
| 8279 (PKD)        | Programmable<br>Keyboard/Display Controller                        |
| 8291A, 8292, 8293 | Programmable GPIB System<br>Talker, Listener, Controller           |

Intelligent devices like the 82077AA floppy disk controller and 8273 synchronous data link controller (see Table 1-1) can preprocess serial data and perform control tasks which off-load the main system processor. Higher overall system throughput is achieved and software complexity is greatly reduced. The intelligent peripheral chips simplify master processor control tasks by performing many functions externally in peripheral hardware rather than internally in main processor software.

Intelligent peripherals also provide system flexibility. They contain on-chip mode registers which are programmed by the master processor during system initialization. These control registers allow the peripheral to be configured into many different operation modes. The user-defined program for the peripheral is stored in main system memory and is transferred to the peripheral's registers whenever a mode change is required. Of course, this type of flexibility requires software overhead in the master system which tends to limit the benefit derived from the peripheral chip.

In the past, intelligent peripherals were designed to handle very specialized tasks. Separate chips were designed for communication disciplines, parallel I/O, keyboard encoding, interval timing, CRT control, etc. Yet, in spite of the large number of devices available and the increased flexibility built into these chips, there is still a large number of microcomputer peripheral control tasks which are not satisfied.

With the introduction of the Universal Peripheral Interface (UPI) microcomputer, Intel has taken the intelligent peripheral concept a step further by providing an intelligent controller that is fully user programmable. It is a complete single-chip microcomputer which can connect directly to a master processor data bus. It has the same advantages of intelligence and flexibility which previous peripheral chips offered. In addition, UPIs are user-programmable: it has 1K/2K bytes of ROM or EPROM memory for program storage plus 64/128/256 bytes of RAM memory UPI-41A, 41AH/42, 42AH respectively for data storage or initialization from the master processor. The UPI device allows a designer to fully specify his control algorithm in the peripheral chip without relying on the master processor. Devices like printer controllers and keyboard scanners can be completely self-contained, relying on the master processor only for data transfer.

The UPI family currently consists of seven components:

- 8741A microcomputer with 1K EPROM memory
- 8741AH microcomputer with 1K OTP EPROM memory
- 8041AH microcomputer with 1K ROM memory
- 8742 microcomputer with 2K EPROM memory
- 8742AH microcomputer with 2K "OTP" EPROM memory
- 8042AH microcomputer with 2K ROM memory
- 8243 I/O expander device

The UPI-41A/41AH/42/42AH family of microcomputers are functionally equivalent except for the type and amount of program memory available with each. In addition, the UPI-41AH/42AH family has a Signature Row outside the EPROM Array. The UPI-41AH/ 42AH family also has a Security Feature which renders the EPROM Array unreadable when set.



All UPI's have the following main features:

- 8-bit CPU
- 8-bit data bus interface registers
- Interval timer/event counter
- Two 8-bit TTL compatible I/O ports
- Resident clock oscillator circuits

The UPI family has the following differences:

| UPI-41A                                                    | UPI-42                                                                       |    | UPI-41AH                                                 |                                                     | UPI-42AH                                                                                                                       |
|------------------------------------------------------------|------------------------------------------------------------------------------|----|----------------------------------------------------------|-----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| 1K x 8 EPROM                                               | 2K x 8 EPROM                                                                 | or | 1K x 8 ROM<br>1K x 8 OTP                                 | or                                                  | 2K x 8 ROM<br>2K x 8 OTP                                                                                                       |
| 64 x 8 RAM                                                 | 128 x 8 RAM                                                                  |    | 128 x 8 RAM                                              | 0.                                                  | 256 x 8 RAM                                                                                                                    |
|                                                            |                                                                              |    | *Se                                                      | et Security                                         | / Feature                                                                                                                      |
|                                                            |                                                                              |    | **Si                                                     | gnature R                                           | low Feature                                                                                                                    |
|                                                            |                                                                              |    | 32 B                                                     | ytes with:                                          |                                                                                                                                |
|                                                            |                                                                              |    | 1. Te                                                    | est Code/                                           | Checksum                                                                                                                       |
|                                                            |                                                                              |    |                                                          | tel Signati                                         |                                                                                                                                |
|                                                            |                                                                              |    |                                                          | ecurity By                                          |                                                                                                                                |
|                                                            |                                                                              |    | 4. Us                                                    | ser Signat                                          | ure                                                                                                                            |
| PROGRAMMING                                                |                                                                              |    |                                                          |                                                     |                                                                                                                                |
| UPI-41A                                                    | UPI-42                                                                       |    | UPI-41AH/UP                                              | I-42AH                                              |                                                                                                                                |
| $V_{DD} = 25V$                                             | 21V                                                                          |    | 12.5V                                                    |                                                     |                                                                                                                                |
| $I_{DD} = 50 \text{ ms}$                                   | 50 mA                                                                        |    | 30 mA                                                    |                                                     |                                                                                                                                |
| EA = 21.5V - 24.5V                                         | 18V                                                                          |    | 12.5V                                                    |                                                     |                                                                                                                                |
| $V_{PH} = 21.5V - 24.5V$                                   | 18V                                                                          |    | 20.V-5.5V                                                |                                                     |                                                                                                                                |
| TPW = 50 ms                                                | 50 ms                                                                        |    | 1 ms                                                     |                                                     |                                                                                                                                |
| PIN DESCRIPTION                                            |                                                                              |    |                                                          |                                                     |                                                                                                                                |
| UPI-41A/UPI-42                                             |                                                                              |    | UPI-41AH/UP                                              | I-42AH                                              |                                                                                                                                |
| directly tested using cor                                  | a test input which can be<br>nditional branching<br>as the event timer input |    | tested using co<br>works as the ev<br>control. It is use | onditional<br>vent timer<br>ed during<br>e to S1 ar | but that can be directly<br>branching instructions. It<br>input under software<br>sync mode to reset the<br>ad synchronize the |
| (SS) Single step inp output to step the progr instruction. | ut used with the sync<br>am through each                                     |    | step the progra                                          | am throug<br>d to put th                            | ith the sync output to<br>h each instruction.<br>e device in sync mode by                                                      |
| Port 1 (P10–P17): 8-bit,<br>Lines.                         | Quasi-Bidirectional I/O                                                      |    |                                                          |                                                     | Quasi-Bidirectional I/O the Signature Row and                                                                                  |

NOTES:

\*For a complete description of the Security Feature, refer to the UPI-41AH/42AH Datasheet. \*\*For a complete description of the Signature Row, refer to the UPI-41AH/42AH Datasheet.

HMOS processing has been applied to the UPI family to allow for additional performance and memory capability while reducing costs. The UPI-41A/41AH/42/42AH are all pin and software compatible. This allows growth in present designs to incorporate new features and add additional performance. For new designs, the additional memory and performance of the UPI-41A/41AH/42/42AH extends the UPI 'grow your own solution' concept to more complex motor control tasks, 80-column printers and process control applications as examples.

The 8243 device is an I/O multiplexer which allows expansion of I/O to over 100 lines (if seven devices are used). All three parts are fabricated with N-channel MOS technology and require a single, 5V supply for operation.

#### INTERFACE REGISTERS FOR MULTI-PROCESSOR CONFIGURATIONS

In the normal configuration, the UPI-41A/41AH/42/ 42AH interfaces to the system bus, just like any intelligent peripheral device (see Figure 1-1). The host processor and the UPI-41A/41AH/42/42AH form a loosely coupled multi-processor system, that is, communications between the two processors are direct. Common resources are three addressable registers located physically on the UPI-41A/41AH/42/42AH. These reg-

#### UPI-41A/41AH/42/42AH USER'S MANUAL

isters are the Data Bus Buffer Input (DBBIN), Data Bus Buffer Output (DBBOUT), and Status (STATUS) registers. The host processor may read data from DBBOUT or write commands and data into DBBIN. The status of DBBOUT and DBBIN plus user-defined status is supplied in STATUS. The host may read STATUS at any time. An interrupt to the UPI processor is automatically generated (if enabled) when DBBIN is loaded.

Because the UPI contains a complete microcomputer with program memory, data memory, and CPU it can function as a "Universal" controller. A designer can program the UPI to control printers, tape transports, or multiple serial communication channels. The UPI can also handle off-line arithmetic processing, or any number of other low speed control tasks.

#### **POWERFUL 8-BIT PROCESSOR**

The UPI contains a powerful, 8-bit CPU with as fast as 1.2  $\mu$ sec cycle time and two single-level interrupts. Its instruction set includes over 90 instructions for easy software development. Most instructions are single byte and single cycle and none are more than two bytes long. The instruction set is optimized for bit manipulation and I/O operations. Special instructions are included to allow binary or BCD arithmetic operations, table look-up routines, loop counters, and N-way branch routines.



Figure 1-1. Interfacing Peripherals To Microcomputer Systems

### intel



Figure 1-2. Pin Compatible ROM/EPROM Versions

### SPECIAL INSTRUCTION SET FEATURES

- For Loop Counters: Decrement Register and Jump if not zero.
- For Bit Manipulation: AND to A (immediate data or Register) OR to A (immediate data or Register) XOR to A (immediate data or Register) AND to Output Ports (Accumulator) OR to Output Ports (Accumulator) Jump Conditionally on any bit in A
- For BDC Arithmetic: Decimal Adjust A Swap 4-bit Nibbles of A Exchange lower nibbles of A and Register Rotate A left or right with or without Carry
- For Lookup Tables: Load A from Page of ROM (Address in A) Load A from Current Page of ROM (Address in A)



Figure 1-3. Interfaces and Protocols for Multiprocessor Systems

#### Features for Peripheral Control

The UPI 8-bit interval timer/event counter can be used to generate complex timing sequences for control applications or it can count external events such as switch closures and position encoder pulses. Software timing loops can be simplified or eliminated by the interval timer. If enabled, an interrupt to the CPU will occur when the timer overflows.

The UPI I/O complement contains two TTL-compatible 8-bit bidirectional I/O ports and two general-purpose test inputs. Each of the 16 port lines can individually function as either input or output under software control. Four of the port lines can also function as an interface for the 8243 I/O expander which provides four additional 4-bit ports that are directly addressable by UPI software. The 8243 expander allows low cost I/O expansion for large control applications while maintaining easy and efficient software port addressing.



Figure 1-4. 8243 I/O Expander Interface

#### **On-Chip Memory**

The UPI's 64/128/256 bytes data memory include dual working register banks and an 8-level program counter stack. Switching between the register banks allows fast response to interrupts. The stack is used to store return addresses and processor status upon entering a subroutine.

#### UPI-41A/41AH/42/42AH USER'S MANUAL

The UPI program memory is available in three types to allow flexibility in moving from design to prototype to production with the same PC layout. The 8741A/8742 device with EPROM memory is very economical for initial system design and development. Its program memory can be electrically programmed using the Intel Universal PROM Programmer. When changes are needed, the entire program can be erased using UV lamp and reprogrammed in about 20 minutes. This means the 8741A/8742 can be used as a single chip "breadboard" for very complex interface and control problems. After the 8741A/8742 is programmed it can be tested in the actual production level PC board and the actual functional environment. Changes required during system debugging can be made in the 8741A/8742 program much more easily than they could be made in a random logic design. The system configuration and PC layout can remain fixed during the development process and the turn around time between changes can be reduced to a minimum.

At any point during the development cycle, the 8741A/8742 EPROM part can be replaced with the low cost UPI-41AH/42AH respectively with factory mask programmed memory or OTP EPROM. The transition from system development to mass production is made smoothly because the 8741A/8742, 8741AH and 8041AH, 8742AH and 8042AH parts are completely pin compatible. This feature allows extensive testing with the EPROM part, even into initial shipments to customers. Yet, the transition to low-cost ROMs or OTP EPROM is simplified to the point of being merely a package substitution.

#### PREPROGRAMMED UPI's

The 8242AH, 8292, and 8294 are 8042AH's that are programmed by Intel and sold as standard peripherals. Intel offers a complete line of factory programmed keyboard controllers. These devices contain firmware developed by Phoenix Technologies Ltd. and Award Software Inc. See Table 1-3 for a complete listing of Intels' entire keyboard controller product line. The 8292 is a GPIB controller, part of a three chip GPIB system. The 8294 is a Data Encryption Unit that implements the National Bureau of Standards data encryption algorithm. These parts illustrate the great flexibility offered by the UPI family.



#### Table 1-3. Keyboard Controller Family Product Selection Guide

| Device                             | Package                      | ROM | ОТР | Comments                                                                                                                                                                       |
|------------------------------------|------------------------------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8042                               | N, P                         | 2K  |     | ROM Device                                                                                                                                                                     |
| 8242<br>8242PC<br>8242WA<br>8242WB | N, P<br>N, P<br>N, P<br>N, P |     |     | Phoenix firmware version 2.5<br>Phoenix MultiKey/42 firmware, PS/2 style mouse support<br>Award firmware version 3.57<br>Award firmware version 4.14, PS/2 style mouse support |
| 8742                               | N, P, D                      |     | 2K  | Available as OTP (N, P) or EPROM (D)                                                                                                                                           |

UPI-42: The industry standard for desktop Keyboard Control.

UPI-C42: A low power CHMOS version of the UPI-42. The UPI-C42 doubles the user programmable memory size, adds Auto A20 Gate support, includes Standby (\*\*) and Suspend power down modes, and is available in a space saving 44-lead QFP pkg.

| Device                        | Package                       | ROM | ОТР | Comments                                                                                                                                                                                |
|-------------------------------|-------------------------------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 80C42                         | N, P, S                       | 4K  |     | ROM Device                                                                                                                                                                              |
| 82C42PC<br>82C42PD<br>82C42PE | N, P, S<br>N, P, S<br>N, P, S |     |     | Phoenix MultiKey/42 firmware, PS/2 style mouse support<br>Phoenix MultiKey/42L firmware, KBC and SCC for portable apps.<br>Phoenix MultiKey/42G firmware, Energy Efficient KBC solution |
| 87C42                         | N, P, S                       |     | 4K  | One Time Programmable Version                                                                                                                                                           |

UPI-L42: The low voltage 3.3V version of the UPI-C42.

| Device             | Package            | ROM | ОТР | Comments                                                                                                                |
|--------------------|--------------------|-----|-----|-------------------------------------------------------------------------------------------------------------------------|
| 80L42              | N, P, S            | 4K  |     | ROM Device                                                                                                              |
| 82L42PC<br>82L42PD | N, P, S<br>N, P, S |     |     | Phoenix MultiKey/42 firmware, PS/2 style mouse support<br>Phoenix MultiKey/42L firmware, KBC and SCC for portable apps. |
| 87L42              | N, P, S            |     | 4K  | One Time Programmable Version                                                                                           |

#### NOTES:

N = 44 lead PLCC, P = 40 lead PDIP, S = 44 lead QFP, D = 40 lead CERDIP KBC = Key Board Control, SCC = Scan Code Control (\*\*) Standby feature not supported on current (B-1) stepping

#### **DEVELOPMENT SUPPORT**

The UPI microcomputer is fully supported by Intel with development tools like the UPP PROM programmer already mentioned. The combination of device features and Intel development support make the UPI an ideal component for low-speed peripheral control applications.

#### **UPI DEVELOPMENT SUPPORT**

- 8048/UPI-41A/41AH/42/42AH Assembler
- Universal PROM Programmer UPP Series
- Application Engineers
- Training Courses

### CHAPTER 2 FUNCTIONAL DESCRIPTION

The UPI microcomputer is an intelligent peripheral controller designed to operate in iAPX-86, 88, MCS-85, MCS-80, MCS-51 and MCS-48 systems. The UPI's architecture, illustrated in Figure 2-1, is based on a low cost, single-chip microcomputer with program memory, data memory, CPU, I/O, event timer and clock oscillator in a single 40-pin package. Special interface registers are included which enable the UPI to function as a peripheral to an 8-bit master processor.

This chapter provides a basic description of the UPI microcomputer and its system interface registers. Unless otherwise noted the descriptions in this section apply to the 8741AH, 8742AH with OTP EPROM mem-

ory, the 8741A/8742 (with UV erasable program memory) and the 8041AH, 8042AH. These devices are so similar that they can be considered identical under most circumstances. All functions described in this chapter apply to the UPI-41A/41AH/42/42AH.

#### **PIN DESCRIPTION**

The UPI-41A/41AH/42/42AH are packaged in 40-pin Dual In-Line (DIP) packages. The pin configuration for both devices is shown in Figure 2-2. Figure 2-3 illustrates the UPI Logic Symbol.



Figure 2-1. UPI-41A/41AH/42/42AH Single Chip Microcomputer



intel



Figure 2-3. Logic Symbol

#### UPI-41A/41AH/42/42AH USER'S MANUAL

The following section summarizes the functions of each UPI pin. NOTE that several pins have two or more functions which are described in separate paragraphs.

|                                         |                |      | Table 2-1. Pin Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------------------------|----------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol                                  | Pin No.        | Туре | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| D <sub>0</sub> -D <sub>7</sub><br>(BUS) | 12–19          | 1/0  | <b>DATA BUS:</b> Three-state, bidirectional DATA BUS BUFFER<br>lines used to interface the UPI-41A/41AH/42/42AH<br>microcomputer to an 8-bit master system data bus.                                                                                                                                                                                                                                                                                                                                                                                 |
| P <sub>10</sub> -P <sub>17</sub>        | 27-34          | I/O  | PORT 1: 8-bit, PORT 1 quasi-bidirectional I/O lines.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| P <sub>20</sub> -P <sub>27</sub>        | 21-24<br>35–38 | 1/0  | <b>PORT 2:</b> 8-bit, PORT 2 quasi-bidirectional I/O lines. The lower 4 bits ( $P_{20}-P_{23}$ ) interface directly to the 8243 I/O expander device and contain address and data information during PORT 4–7 access. The upper 4 bits ( $P_{24}-P_{27}$ ) can be programmed to provide interrupt Request and DMA Handshake capability. Software control can configure $P_{24}$ as Output Buffer Full (OBF) interrupt, $P_{25}$ as Input Buffer Full (IBF) interrupt, $P_{26}$ as DMA Request ( <u>DRQ</u> ), and $P_{27}$ as DMA AcKnowledge (DACK). |
| WR                                      | 10             | I    | WRITE: I/O write input which enables the master CPU to write data and command words to the UPI INPUT DATA BUS BUFFER.                                                                                                                                                                                                                                                                                                                                                                                                                                |
| RD                                      | 8              | I    | <b>READ:</b> I/O read input which enables the master CPU to read data and status words from the OUTPUT DATA BUS BUFFER or status register.                                                                                                                                                                                                                                                                                                                                                                                                           |
| CS                                      | 6              | I    | CHIP SELECT: Chip select input used to select one UPI-<br>41A/41AH/42/42AH microcomputer out of several<br>connected to a common data bus.                                                                                                                                                                                                                                                                                                                                                                                                           |
| A <sub>0</sub>                          | 9              | 1    | <b>COMMAND/DATA SELECT:</b> Address input used by the master processor to indicate whether byte transfer is data $(A_0 = 0)$ or command $(A_0 = 1)$ .                                                                                                                                                                                                                                                                                                                                                                                                |
| TEST 0,<br>TEST 1                       | 1<br>39        |      | <b>TEST INPUTS:</b> Input pins can be directly tested using conditional branch instructions.<br><b>FREQUENCY REFERENCE:</b> TEST 1 (T <sub>1</sub> ) also functions as the event timer input (under software control). TEST0 (T <sub>0</sub> ) is used during PROM programming and verification in the UPI-41A/41AH/42/42AH.                                                                                                                                                                                                                         |
| XTAL 1,<br>XTAL 2                       | 2<br>3         | I    | <b>INPUTS:</b> Inputs for a crystal, LC or an external timing signal to determine the internal oscillator frequency.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| SYNC                                    | 11             | 0    | <b>OUTPUT CLOCK:</b> Output signal which occurs once per UPI instruction cycle. SYNC can be used as a strobe for external circuitry; it is also used to synchronize single step operation.                                                                                                                                                                                                                                                                                                                                                           |
| EA                                      | 7              | I    | <b>EXTERNAL ACCESS:</b> External access input which allows emulation, testing and PROM/ROM verification.                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| PROG                                    | 25             | 1/0  | <b>PROGRAM:</b> Multifunction pin used as the program pulse input during PROM programming.<br>During I/O expander access the PROG pin acts as an address/data strobe to the 8243.                                                                                                                                                                                                                                                                                                                                                                    |
| RESET                                   | 4              | I    | <b>RESET:</b> Input used to reset <u>status</u> flip-flops and to set the program counter to zero. RESET is also used during PROM programming and verification.                                                                                                                                                                                                                                                                                                                                                                                      |
| SS                                      | 5              | I    | <b>SINGLE STEP:</b> Single step input used in conjunction with the SYNC output to step the program through each instruction.                                                                                                                                                                                                                                                                                                                                                                                                                         |
| V <sub>CC</sub>                         | 40             |      | <b>POWER:</b> +5V main power supply pin.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| V <sub>DD</sub>                         | 26             |      | <b>POWER:</b> +5V during normal operation. +25V for UPI-41A,<br>21V for UPI-42 programming operation, +12V for<br>programming, UPI-41AH/42AH. Low power standby pin in<br>ROM version.                                                                                                                                                                                                                                                                                                                                                               |
| V <sub>SS</sub>                         | 20             |      | GROUND: Circuit ground potential.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

The following sections provide a detailed functional description of the UPI microcomputer. Figure 2-4 illustrates the functional blocks within the UPI device.

#### **CPU SECTION**

The CPU section of the UPI-41A/41AH/42/42AH microcomputer performs basic data manipulations and controls data flow throughout the single chip computer via the internal 8-bit data bus. The CPU section includes the following functional blocks shown in Figure 2-4:

- Arithmetic Logic Unit (ALU)
- Instruction Decoder
- Accumulator
- Flags

#### Arithmetic Logic Units (ALU)

The ALU is capable of performing the following operations:

- ADD with or without carry
- AND, OR, and EXCLUSIVE OR
- Increment, Decrement
- Bit complement
- Rotate left or right
- Swap
- · BCD decimal adjust

### intel

In a typical operation data from the accumulator is combined in the ALU with data from some other source on the UPI-41A/41AH/42/42AH internal bus (such as a register or an I/O port). The result of an ALU operation can be transferred to the internal bus or back to the accumulator.

If an operation such as an ADD or ROTATE requires more than 8 bits, the CARRY flag is used as an indicator. Likewise, during decimal adjust and other BCD operations the AUXILIARY CARRY flag can be set and acted upon. These flags are part of the Program Status Word (PSW).

#### Instruction Decoder

During an instruction fetch, the operation code (opcode) portion of each program instruction is stored and decoded by the instruction decoder. The decoder generates outputs used along with various timing signals to control the functions performed in the ALU. Also, the instruction decoder controls the source and destination of ALU data.

#### Accumulator

The accumulator is the single most important register in the processor. It is the primary source of data to the ALU and is often the destination for results as well. Data to and from the I/O ports and memory normally passes through the accumulator.



Figure 2-4. UPI-41A/41AH/42/42AH Block Diagram

#### PROGRAM MEMORY

The UPI-41A/41AH/42/42AH microcomputer has 1024, 2048 8-bit words of resident, read-only memory for program storage. Each of these memory locations is directly addressable by a 10-bit program counter. Depending on the type of application and the number of program changes anticipated, three types of program memory are available:

- 8041AH, 8042AH with mask programmed ROM Memory
- 8741AH, 8742AH with electrically programmable OTP EPROM Memory
- 8741A and 8742 with electrically programmable EPROM Memory

A program memory map is illustrated in Figure 2-5. Memory is divided into 256 location 'pages' and three locations are reserved for special use:



Figure 2-5. Program Memory Map

#### UPI-41A/41AH/42/42AH USER'S MANUAL

#### **INTERRUPT VECTORS**

- 1) Location 0
- Following a **RESET** input to the processor, the next instruction is automatically fetched from location 0.
- Location 3
   An interrupt generated by an Input Buffer Full (IBF) condition (when the IBF interrupt is enabled) causes the next instruction to be fetched from location 3.
- 3) Location 7
- A timer overflow interrupt (when enabled) will cause the next instruction to be fetched from location 7.

Following a system  $\overrightarrow{\text{RESET}}$ , program execution begins at location 0. Instructions in program memory are normally executed sequentially. Program control can be transferred out of the main line of code by an input buffer full (IBF) interrupt or a timer interrupt, or when a jump or call instruction is encountered. An IBF interrupt (if enabled) will automatically transfer control to location 3 while a timer interrupt will transfer control to location 7.

All conditional JUMP instructions and the indirect JUMP instruction are limited in range to the current 256-location page (that is, they alter PC bits 0-7 only). If a conditional JUMP or indirect JUMP begins in location 255 of a page, it must reference a destination on the following page.

Program memory can be used to store constants as well as program instructions. The UPI-41AH, 42AH instruction set contains an instruction (MOVP3) designed specifically for efficient transfer of look-up table information from page 3 of memory.

#### DATA MEMORY

The UPI-41A has 64 8-bit words of Random Access Memory, the UPI-41AH has 128 8-bit words of Random Access Memory; the UPI-42 has 128 8-bit words of RAM; and the UPI-42AH has 256 8-bit words of RAM. This memory contains two working register banks, an 8-level program counter stack and a scratch pad memory, as shown in Figure 2-6. The amount of scratch pad memory available is variable depending on the number of addresses nested in the stack and the number of working registers being used.

#### Addressing Data Memory

The first eight locations in RAM are designated as working registers  $R_0-R_7$ . These locations (or registers) can be addressed directly by specifying a register number in the instruction. Since these locations are easily addressed, they are generally used to store frequently



accessed intermediate results. Other locations in data memory are addressed indirectly by using  $R_0$  or  $R_1$  to specify the desired address.



Figure 2-6. Data Memory Map

#### **Working Registers**

Dual banks of eight working registers are included in the UPI-41A/41AH/42/42AH data memory. Locations 0–7 make up register bank 0 and locations 24–13 form register bank 1. A RESET signal automatically selects register bank 0. When bank 0 is selected, references to  $R_0-R_7$  in UPI-41A/41AH/42/42AH instructions operate on locations 0–7 in data memory. A "select register bank" instruction is used to selected between the banks during program execution. If the instruction SEL RB1 (Select Register Bank 1) is executed, then program references to  $R_0-R_7$  will operate on locations 24–31. As stated previously, registers 0 and 1 in the active register bank are used as indirect address registers for all locations in data memory.

Register bank 1 is normally reserved for handling interrupt service routines, thereby preserving the contents of the main program registers. The SEL RB1 instruction can be issued at the beginning of an interrupt service routine. Then, upon return to the main program, an RETR (return & restore status) instruction will automatically restore the previously selected bank. During interrupt processing, registers in bank 0 can be accessed indirectly using  $R_{0^\prime}$  and  $R_{1^\prime}$ .

If register bank 1 is not used, registers 24-31 can still serve as additional scratch pad memory.

#### **Program Counter Stack**

RAM locations 8–23 are used as an 8-level program counter stack. When program control is temporarily passed from the main program to a subroutine or interrupt service routine, the 10-bit program counter and bits 4–7 of the program status word (PSW) are stored in two stack locations. When control is returned to the main program via an RETR instruction, the program counter and PSW bits 4–7 are restored. Returning via an RET instruction does not restore the PSW bits, however. The program counter stack is addressed by three stack pointer bits in the PSW (bits 0–2). Operation of the program counter stack and the program status word is explained in detail in the following sections.

The stack allows up to eight levels of subroutine 'nesting'; that is, a subroutine may call a second subroutine, which may call a third, etc., up to eight levels. Unused stack locations can be used as scratch pad memory. Each unused level of subroutine nesting provides two additional RAM locations for general use.

The following sections provide a detailed description of the Program Counter Stack and the Program Status Word.

#### **PROGRAM COUNTER**

The UPI-41A/41AH/42/42AH microcomputer has a 10-bit program counter (PC) which can directly address any of the 1024, 2048, or 4096 locations in program memory. The program counter always contains the address of the next instruction to be executed and is normally incremented sequentially for each instruction to be executed when each instruction fetches occurs.

When control is temporarily passed from the main program to a subroutine or an interrupt routine, however, the PC contents must be altered to point to the address of the desired routine. The stack is used to save the current PC contents so that, at the end of the routine, main program execution can continue. The program counter is initialized to zero by a  $\overrightarrow{RESET}$  signal.

#### **PROGRAM COUNTER STACK**

The Program Counter Stack is composed of 16 locations in Data Memory as illustrated in Figure 2-7. These RAM locations (8 through 23) are used to store the 10-bit program counter and 4 bits of the program status word.

An interrupt or Call to a subroutine causes the contents of the program counter to be stored in one of the 8 register pairs of the program counter stack.



Figure 2-7. Program Counter Stack

A 3-bit Stack Pointer which is part of the Program Status Word (PSW) determines the stack pair to be used at a given time. The stack pointer is initialized by a RESET signal to 00H which corresponds to RAM locations 8 and 9.

The first call or interrupt results in the program counter and PSW contents being transferred to RAM locations 8 and 9 in the format shown in Figure 2-7. The stack pointer is automatically incremented by 1 to point to location is 10 and 11 in anticipation of another CALL.

Nesting of subroutines within subroutines can continue up to 8 levels without overflowing the stack. If overflow does occur the deepest address stored (locations 8 and 9) will be overwritten and lost since the stack pointer overflows from 07H to 00H. Likewise, the stack pointer will underflow from 00H to 07H.

The end of a subroutine is signaled by a return instruction, either RET or RETR. Each instruction will automatically decrement the Stack Pointer and transfer the contents of the proper RAM register pair to the Program Counter.

#### **PROGRAM STATUS WORD**

The 8-bit program status word illustrated in Figure 2-8 is used to store general information about program execution. In addition to the 3-bit Stack Pointer discussed previously, the PSW includes the following flags:

- UPI-41A/41AH/42/42AH USER'S MANUAL
- CY Carry
- AC Auxiliary Carry
- F<sub>0</sub> Flag 0
- BS Register Bank Select





The Program Status Word (PSW) is actually a collection of flip-flops located throughout the machine which are read or written as a whole. The PSW can be loaded to or from the accumulator by the MOV A, PSW or MOV PSW, A instructions. The ability to write directly to the PSW allows easy restoration of machine status after a power-down sequence.

The upper 4 bits of the PSW (bits 4, 5, 6, and 7) are stored in the PC Stack with every subroutine CALL or interrupt vector. Restoring the bits on a return is optional. The bits are restored if an RETR instruction is executed, but not if an RET is executed.

PSW bit definitions are as follows:

- Bits 0-2 Stack Pointer Bits S<sub>0</sub>, S<sub>1</sub>, S<sub>2</sub>
- Bit 3 Not Used
- Bit 4 Working Register Bank
  - 0 = Bank 0
  - 1 = Bank 1
- Bit 5 Flag 0 bit (F<sub>0</sub>)

This is a general purpose flag which can be cleared or complemented and tested with conditional jump instructions. It may be used during data transfer to an external processor.

- Bit 6 Auxiliary Carry (AC) The flag status is determined by an ADD instruction and is used by the Decimal Adjustment instruction DAA
- Bit 7 Carry (CY)

The flag indicates that a previous operation resulted in overflow of the accumulator.

#### CONDITIONAL BRANCH LOGIC

Conditional Branch Logic in the UPI-41AH, 42AH allows the status of various processor flags, inputs, and other hardware functions to directly affect program execution. The status is sampled in state 3 of the first cycle.



Table 2-2 lists the internal conditions which are testable and indicates the condition which will cause a jump. In all cases, the destination address must be within the page of program memory (256 locations) in which the jump instruction occurs.

#### OSCILLATOR AND TIMING CIRCUITS

The UPI-41A/41AH/42/42AH's internal timing generation is controlled by a self-contained oscillator and timing circuit. A choice of crystal, L-C or external clock can be used to derive the basic oscillator frequency.

The resident timing circuit consists of an oscillator, a state counter and a cycle counter as illustrated in Figure 2-9. Figure 2-10 shows instruction cycle timing.

which UPI is used. Refer to Table 1.1. Pins XTAL 1 and XTAL 2 are input and output (respectively) of a high gain amplifier stage. A crystal or inductor and capacitor connected between XTAL 1 and XTAL 2 provide the feedback and proper phase shift for oscillation. Recommended connections for crystal or L-C are shown in Figure 2-11.

#### State Counter

The output of the oscillator is divided by 3 in the state counter to generate a signal which defines the state times of the machine.

Each instruction cycle consists of five states as illustrated in Figure 2-10 and Table 2-3. The overlap of address and execution operations illustrated in Figure 2-10 allows fast instruction execution.

#### Oscillator

The on-board oscillator is a series resonant circuit with a frequency range of 1 to 12.5 MHz depending on

| Device             | Instruction Mne | emonic | Jump Condition<br>Jump if: |
|--------------------|-----------------|--------|----------------------------|
| Accumulator        | JZ              | addr   | All bits zero              |
|                    | JNZ             | addr   | Any bit not zero           |
| Accumulator bit    | JBb             | addr   | Bit "b" = 1                |
| Carry flag         | JC              | addr   | Carry flag $= 1$           |
|                    | JNC             | addr   | Carry flag = 0             |
| User flag          | JFO             | addr   | $F_0$ flag = 1             |
|                    | JF1             | addr   | $F_1$ flag = 1             |
| Timer flag         | JTF             | addr   | Timer flag = 1             |
| Test Input 0       | JT0             | addr   | $T_0 = 1$                  |
|                    | JNT0            | addr   | $T_0 = 0$                  |
| Test Input 1       | JT1             | addr   | $T_1 = 1$                  |
|                    | JNT1            | addr   | $T_1 = 0$                  |
| Input Buffer flag  | JNIBF           | addr   | IBF flag = 0               |
| Output Buffer flag | JOBF            | addr   | OBF flag = 1               |

#### Table 2-2. Conditional Branch Instructions





Figure 2-9. Oscillator Configuration

#### Figure 2-10. Instruction Cycle Timing

#### UPI-41A/41AH/42/42AH USER'S MANUAL

| Instruction        |                      |                                 | CYCLE 1                  |                            |                            |                            | CYCLE            | 2                               |                   |            |
|--------------------|----------------------|---------------------------------|--------------------------|----------------------------|----------------------------|----------------------------|------------------|---------------------------------|-------------------|------------|
| instruction        | S1                   | S2                              | S3                       | S4                         | S5                         | S1                         | S2               | S3                              | S4                | <b>S</b> 5 |
| IN A,Pp            | Fetch<br>Instruction | Increment<br>Program Counter    | _                        | Increment<br>Timer         | _                          | _                          | Read Port        | _                               | _                 | _          |
| OUTL Pp,A          | Fetch<br>Instruction | Increment<br>Program Counter    | —                        | Increment<br>Timer         | Output<br>To Port          | _                          | _                | _                               | _                 | _          |
| ANL Pp, DATA       | Fetch<br>Instruction | Increment<br>Program<br>Counter | _                        | Increment<br>Timer         | Read Port                  | Fetch<br>Immediate<br>Data | _                | Increment<br>Program<br>Counter | Output<br>To Port | _          |
| ORL Pp, DATA       | Fetch<br>Instruction | Increment<br>Program<br>Counter | _                        | Increment<br>Timer         | Read Port                  | Fetch<br>Immediate<br>Data | _                | Increment<br>Program<br>Counter | Output<br>To Port |            |
| MOVD A,Pp          | Fetch<br>Instruction | Increment<br>Program Counter    | Output<br>Opcode/Address | Increment<br>Timer         | _                          | _                          | Read<br>P2 Lower | _                               | _                 | _          |
| MOVD Pp, A         | Fetch<br>Instruction | Increment<br>Program Counter    | Output<br>Opcode/Address | Increment<br>Timer         | Output Data<br>To P2 Lower | _                          | _                | _                               | _                 | _          |
| D Pp, A            | Fetch<br>Instruction | Increment<br>Program Counter    | Output<br>Opcode/Address | Increment<br>Timer         | Output<br>Data             | _                          | _                | _                               | _                 | _          |
| ORLD Pp, A         | Fetch<br>Instruction | Increment<br>Program Counter    | Output<br>Opcode/Address | Increment<br>Timer         | Output<br>Data             | _                          | _                | _                               | _                 | _          |
| J (Conditional)    | Fetch<br>Instruction | Increment<br>Program Counter    | Sample<br>Condition      | Increment<br>Timer         | _                          | Fetch<br>Immediate Data    | _                | Update<br>Program<br>Counter    | _                 | _          |
| MOV STS, A         | Fetch<br>Instruction | Increment<br>Program Counter    | _                        | Increment<br>Timer         | Update<br>Status Register  |                            |                  |                                 |                   |            |
| IN A, DBB          | Fetch<br>Instruction | Increment<br>Program Counter    | _                        | Increment<br>Timer         | _                          |                            |                  |                                 |                   |            |
| OUT DBB, A         | Fetch<br>Instruction | Increment<br>Program Counter    | _                        | Increment<br>Timer         | Output<br>To Port          |                            |                  |                                 |                   |            |
| STRT T<br>STRT CNT | Fetch<br>Instruction | Increment<br>Program Counter    | —                        | —                          | Start<br>Counter           |                            |                  |                                 |                   |            |
| STOP TCNT          | Fetch<br>Instruction | Increment<br>Program Counter    | —                        | —                          | Stop<br>Counter            |                            |                  |                                 |                   |            |
| EN I               | Fetch<br>Instruction | Increment<br>Program Counter    | —                        | Enable<br>Interrupt        | _                          |                            |                  |                                 |                   |            |
| DIS I              | Fetch<br>Instruction | Increment<br>Program Counter    | _                        | Disable<br>Interrupt       | _                          |                            |                  |                                 |                   |            |
| EN DMA             | Fetch<br>Instruction | Increment<br>Program Counter    | —                        | DMA Enabled<br>DRQ Cleared | _                          |                            |                  |                                 |                   |            |
| EN FLAGS           | Fetch<br>Instruction | Increment<br>Program Counter    | —                        | OBF, IBF<br>Output Enabled | -                          |                            |                  |                                 |                   |            |

#### Table 2-3. Instruction Timing Diagram



Figure 2-11. Recommended Crystal and L-C Connections

#### **Cycle Counter**

The output of the state counter is divided by 5 in the cycle counter to generate a signal which defines a machine cycle. This signal is call SYNC and is available continuously on the SYNC output pin. It can be used to synchronize external circuitry or as a general purpose clock output. It is also used for synchronizing single-step.

#### **Frequency Reference**

The external crystal provides high speed and accurate timing generation. A crystal frequency of 5.9904 MHz is useful for generation of standard communication frequencies by the UPI-41A/41AH/42/42AH. However, if an accurate frequency reference and maximum processor speed are not required, an inductor and capacitor may be used in place of the crystal as shown in Figure 2-11.

A recommended range of inductance and capacitance combinations is given below:

- $L = 130 \ \mu H$  corresponds to 3 MHz
- $L = 45 \ \mu H$  corresponds to 5 MHz

An external clock signal can also be used as a frequency reference to the UPI-41A/41AH/42/42AH; however, the levels are *not* TTL compatible. The signal must be in the 1–12.5 MHz frequency range depending on which UPI is used. Refer to Table 1-2. The signal must be connected to pins XTAL 1 and XTAL 2 by buffers with a suitable pull-up resistor to guarantee that a logic "1" is above 3.8 volts. The recommended connection is shown in Figure 2-12.



Figure 2-12. Recommended Connection For External Clock Signal



#### **INTERVAL TIMER/EVENT COUNTER**

The UPI-41A/41AH/42/42AH has a resident 8-bit timer/counter which has several software selectable modes of operation. As an interval timer, it can generate accurate delays from 80 microseconds to 20.48 milliseconds without placing undue burden on the processor. In the counter mode, external events such as switch closures or tachometer pulses can be counted and used to direct program flow.

#### **Timer Configuration**

Figure 2-13 illustrates the basic timer/counter configuration. An 8-bit register is used to count pulses from either the internal clock and prescaler or from an external source. The counter is presettable and readable with two MOV instructions which transfer the contents of the accumulator to the counter and vice-versa (i.e. MOV T, A and MOV A, T). The counter is stopped by a RESET or STOP TCNT instruction and remains stopped until restarted either as a timer (START T instruction) or as a counter (START CNT instruction). Once started, the counter will increment to its maximum count (FFH) and overflow to zero continuing its count until stopped by a STOP TCNT instruction or RESET.

The increment from maximum count to zero (overflow) results in setting the Timer Flag (TF) and generating an interrupt request. The state of the overflow flag is testable with the conditional jump instruction, JTF. The flag is reset by executing a JTF or by a  $\overrightarrow{\text{RESET}}$  signal.

The timer interrupt request is stored in a latch and ORed with the input buffer full interrupt request. The timer interrupt can be enabled or disabled independent of the IBF interrupt by the EN TCNTI and DIS TCTNI instructions. If enabled, the counter overflow will cause a subroutine call to location 7 where the timer service routine is stored. If the timer and Input Buffer Full interrupts occur simultaneously, the IBF source will be recognized and the call will be to location 3. Since the timer interrupt is latched, it will remain pending until the DBBIN register has been serviced and will immediately be recognized upon return from the service routine. A pending timer interrupt is reset by the initiation of a timer interrupt service routine.

#### Event Counter Mode

The STRT CNT instruction connects the TEST 1 input pin to the counter input and enables the counter. Note this instruction does not clear the counter. The counter is incremented on high to low transitions of the TEST 1 input. The TEST 1 input must remain high for a minimum of one state in order to be registered (250 ns at 12 MHz). The maximum count frequency is one count per three instruction cycles (267 kHz at 12 MHz). There is no minimum frequency limit.

#### **Timer Mode**

The STRT T instruction connects the internal clock to the counter input and enables the counter. The input clock is derived from the SYNC signal of the internal oscillator and the divide-by-32 prescaler. The configuration is illustrated in Figure 2-13. Note this instruction does not clear the timer register. Various delays and timing sequences between 40 µsec and 10.24 msec can easily be generated with a minimum of software timing loops (at 12 MHz).

Times longer than 10.24 msec can be accurately measured by accumulating multiple overflows in a register under software control. For time resolution less than 40  $\mu$ sec, an external clock can be applied to the TEST 1 counter input (see Event Counter Mode). The minimum time resolution with an external clock is 3.75  $\mu$ sec (267 kHz at 12 MHz).

#### **TEST 1 Event Counter Input**

The TEST 1 pin is multifunctional. It is automatically initialized as a test input by a RESET signal and can be tested using UPI-41A conditional branch instructions.

In the second mode of operation, illustrated in Figure 2-13, the TEST 1 pin is used as an input to the internal

#### UPI-41A/41AH/42/42AH USER'S MANUAL

8-bit event counter. The Start Counter (STRT CNT) instruction controls an internal switch which connects TEST 1 through an edge detector to the 8-bit internal counter. Note that this instruction does not inhibit the testing of TEST 1 via conditional Jump instructions.

In the counter mode the TEST 1 input is sampled once per instruction cycle. After a high level is detected, the next occurrence of a low level at TEST 1 will cause the counter to increment by one.

The event counter functions can be stopped by the Stop Timer/Counter (STOP TCNT) instruction. When this instruction is executed the TEST 1 pin becomes a test input and functions as previously described.

#### **TEST INPUTS**

There are two multifunction pins designated as Test Inputs, TEST 0 and TEST 1. In the normal mode of operation, status of each of these lines can be directly tested using the following conditional Jump instructions:

- JT0 Jump if TEST 0 = 1
- JNT0 Jump if TEST 0 = 0
- JT1 Jump if TEST 1 = 1
- JNT1 Jump if TEST 1 = 0



Figure 2-13. Timer Counter

intel

The test imputs are TTL compatible. An external logic signal connected to one of the test inputs will be sampled at the time the appropriate conditional jump instruction is executed. The path of program execution will be altered depending on the state of the external signal when sampled.

#### **INTERRUPTS**

The UPI-41A/41AH/42/42AH has the following internal interrupts:

- Input Buffer Full (IBF) interrupt
- Timer Overflow interrupt

The IBF interrupt forces a CALL to location 3 in program memory; a timer-overflow interrupts forces a CALL to location 7. The IBF interrupt is enabled by the EN I instruction and disabled by the DIS I instruction. The timer-overflow interrupt is enabled and disabled by the EN TNCTI and DIS TCNTI instructions, respectively. Figure 2-14 illustrates the internal interrupt logic. An IBF interrupt request is generated whenever  $\overline{WR}$  and  $\overline{CS}$  are both low, regardless of whether interrupts are enabled. The interrupt request is cleared upon entering the IBF service routine only. That is, the DIS I instruction does not clear a pending IBF interrupt.

#### Interrupt Timing Latency

When the IBF interrupt is enabled and an IBF interrupt request occurs, an interrupt sequence is intiated as soon as the currently executing instruction is completed. The following sequence occurs:

- A CALL to location 3 is forced.
- The program counter and bits 4–7 of the Program Status Word are stored in the stack.
- The stack pointer is incremented.



Figure 2-14. Interrupt Logic

Location 3 in program memory should contain an unconditional jump to the beginning of the IBF interrupt service routine elsewhere in program memory. At the end of the service routine, an RETR (Return and Restore Status) instruction is used to return control to the main program. This instruction will restore the program counter and PSW bits 4–7, providing automatic restoration of the previously active register bank as well. RETR also re-enables interrupts.

A timer-overflow interrupt is enabled by the EN TCNTI instruction and disabled by the DIS TCNTI instruction. If enabled, this interrupt occurs when the timer/counter register overflows. A CALL to location 7 is forced and the interrupt routine proceeds as described above.

The interrupt service latency is the sum of current instruction time, interrupt recognition time, and the internal call to the interrupt vector address. The worst case latency time for servicing an interrupt is 7 clock cycles. Best case latency is 4 clock cycles.

#### Interrupt Timing

Interrupt inputs may be enabled or disabled under program control using EN I, DIS I, EN TCNTI and DIS TCNTI instructions. Also, a **RESET** input will disable interrupts. An interrupt request must be removed before the **RETR** instruction is executed to return from the service routine, otherwise the processor will reenter the service routine immediately. Thus, the **WR** and **CS** inputs should not be held low longer than the duration of the interrupt service routine.

The interrupt system is single level. Once an interrupt is detected, all further interrupt requests are latched but are not acted upon until execution of an RETR instruction re-enables the interrupt input logic. This occurs at the beginning of the second cycle of the RETR instruction. If an IBF interrupt and a timer-overflow interrupt occur simultaneously, the IBF interrupt will be recognized first and the timer-overflow interrupt will remain pending until the end of the interrupt service routine.

#### **External Interrupts**

An external interrupt can be created using the UPI-41A/41AH/42/42AH timer/counter in the event counter mode. The counter is first preset to FFH and the EN TCNTI instruction is executed. A timer-overflow interrupt is generated by the first high to low tran-

#### UPI-41A/41AH/42/42AH USER'S MANUAL

sition of the TEST 1 input pin. Also, if an IBF interrupt occurs during servicing of the timer/counter interrupt, it will remain pending until the end of the service routine.

#### **Host Interrupts And DMA**

If needed, two external interrupts to the host system can be created using the EN FLAGS instruction. This instruction allocates two I/O lines on PORT 2 ( $P_{24}$  and  $P_{25}$ ).  $P_{24}$  is the Output Buffer Full interrupt request line to the host system;  $P_{25}$  is the Input Buffer empty interrupt request line. These interrupt outputs reflect the internal status of the OBF flag and the IBF inverted flag. Note, these outputs may be inhibited by writing a "0" to these pins. Reenabling interrupts is done by writing a "1" to these port pins. Interrupts are typically enabled after power on since the I/O ports are set in a "1" condition. The EN FLAG's effect is only cancelled by a device RESET.

DMA handshaking controls are available from two pins on PORT 2 of the UPI-41A/41AH/42/42AH microcomputer. These lines ( $P_{26}$  and  $P_{27}$ ) are enabled by the EN DMA instruction.  $P_{26}$  becomes DMA request (DRQ) and  $P_{27}$  becomes DMA acknowledge (DACK). The UPI program initiates a DMA request by writing a "1" to  $P_{26}$ . The DMA controller transfers the data into the DBBIN data register using DACK which acts as a chip select. The EN DMA instruction can only be cancelled by a chip RESET.

#### RESET

The RESET input provides a means for internal initialization of the processor. An automatic initialization pulse can be generated at power-on by simply connecting a 1  $\mu$ fd capacitor between the RESET input and ground as shown in Figure 2-15. It has an internal pull-up resistor to charge the capacitor and a Schmitttrigger circuit to generate a clean transition. A 2-stage synchronizer has been added to support reliable operation up to 12.5 MHz.

If automatic initialization is used,  $\overline{\text{RESET}}$  should be held low for at least 10 milliseconds to allow the power supply to stabilize. If an external  $\overline{\text{RESET}}$  signal is used,  $\overline{\text{RESET}}$  may be held low for a minimum of 8 instruction cycles. Figure 2-15 illustrates a configuration using an external TTL gate to generate the  $\overline{\text{RESET}}$  input. This configuration can be used to derive the  $\overline{\text{RESET}}$ signal from the 8224 clock generator in an 8080 system.





Figure 2-15. External Reset Configuration

- The  $\overline{\text{RESET}}$  input performs the following functions:
- Disables Interrupts
- Clears Program Counter to Zero
- Clears Stack Pointer
- Clears Status Register and Flags
- Clears Timer and Timer Flag
- Stops Timer
- Selects Register Bank 0
- Sets PORTS 1 and 2 to Input Mode

#### DATA BUS BUFFER

Two 8-bit data bus buffer registers, DBBIN and DBBOUT, serve as temporary buffers for commands and data flowing between it and the master processor. Externally, data is transmitted or received by the DBB registers upon execution of an INput or OUTput instruction by the master processor. Four control signals are used:

- A<sub>0</sub> Address input signifying control or data
- $\overline{\text{CS}}$  Chip Select
- RD Read Strobe
- $\overline{WR}$  Write Strobe

Transfer can be implemented with or without UPI program interference by enabling or disabling an internal UPI interrupt. Internally, data transfer between the DBB and the UPI accumulator is under software control and is completely asynchronous to the external processor timing. This allows the UPI software to handle peripheral control tasks independent of the main processor while still maintaining a data interface with the master system.

#### Configuration

Figure 2-16 illustrates the internal configuration of the DBB registers. Data is stored in two 8-bit buffer registers, DBBIN and DBBOUT. DBBIN and DBBOUT may be accessed by the external processor using the WR line and the  $\overline{RD}$  line, respectively. The data bus is a bidirectional, three-state bus which can be connected directly to an 8-bit microprocessor system. Four control lines (WR, RD,  $\overline{CS}$ , A<sub>0</sub>) are used by the external processor to transfer data to and from the DBBIN and DBBOUT registers.

An 8-bit register containing status flags is used to indicate the status of the DBB registers. The eight status flags are defined as follows:

• OBF Output Buffer Full

This flag is automatically set when the UPI-Microcomputer loads the DBBOUT register and is cleared when the master processor reads the data register.

• IBF Input Buffer Full

This flag is set when the master processor writes a character to the DBBIN register and is cleared when the UPI INputs the data register contents to its accumulator.





• F<sub>0</sub>

This is a general purpose flag which can be cleared or toggled under UPI software control. The flag is used to transfer UPI status information to the master processor.

• F<sub>1</sub> Command/Data

This flag is set to the condition of the  $A_0$  input line when the master processor writes a character to the data register. The  $F_1$  flag can also be cleared or toggled under UPI-Microcomputer program control.

ST4 through ST7

These bits are user defined status bits. They are defined by the MOV STS,A instruction.

#### SYSTEM INTERFACE

Figure 2-17 illustrates how a UPI-Microcomputer can be connected to a standard 8080-type bus system. Data lines  $D_0-D_7$  form a three-state, bidirectional port which can be connected directly to the system data bus. The UPI bus interface has sufficient drive capability (400  $\mu$ A) for small systems, however, a larger system may require buffers.

Four control signals are required to handle the data and status information transfer:

• WR

I/O WRITE signal used to transfer data from the system bus to the UPI DBBIN register and set the  $F_1$  flag in the status register.

• RD

I/O READ signal used to transfer data from the DBBOUT register or status register to the system data bus.

•  $\overline{CS}$ 

CHIP SELECT signal used to enable one 8041AH out of several connected to a common bus.

•  $\overline{A_0}$ 

Address input used to select either the 8-bit status register or DBBOUT register during an I/O READ. Also, the signal is used to set the  $F_1$  flag in the status register during an I/O WRITE.

The WR and RD signals are active low and are standard MCS-80 peripheral control signals used to synchronize data transfer between the system bus and peripheral devices.

The  $\overline{CS}$  and  $A_0$  signals are decoded from the address bus of the master system. In a system with few I/O devices a linear addressing configuration can be used where  $A_0$  and  $A_1$  lines are connected directly to  $A_0$  and  $\overline{CS}$  inputs (see Figure 2-17).

#### Data Read

Table 2-4 illustrates the relative timing of a DBBOUT Read. When  $\overline{CS}$ , A<sub>0</sub>, and  $\overline{RD}$  are low, the contents of the DBBOUT register is placed on the three-state Data lines D<sub>0</sub>-D<sub>7</sub> and the OBF flag is cleared.

The master processor uses  $\overline{CS}$ ,  $A_0$ ,  $\overline{WR}$ , and  $\overline{RD}$  to control data transfer between the DBBOUT register and the master system. The following operations are under master processor control:



Figure 2-17. Interface to 8080 System Bus

| CS | RD | WR | A <sub>0</sub> |                              |
|----|----|----|----------------|------------------------------|
| 0  | 0  | 1  | 0              | Read DBBOUT register         |
| 0  | 0  | 1  | 1              | Read STATUS register         |
| 0  | 1  | 0  | 0              | Write DBBIN data register    |
| 0  | 1  | 0  | 1              | Write DBBIN command register |
| 1  | х  | х  | х              | Disable DBB                  |

#### **Status Read**

Table 2-4 shows the logic sequence required for a STATUS register read. When  $\overline{CS}$  and  $\overline{RD}$  are low with A<sub>0</sub> high, the contents of the 8-bit status register appears on Data lines D<sub>0</sub>-D<sub>7</sub>.

#### **Data Write**

Table 2-4 shows the sequence for writing information to the DBBIN register. When  $\overline{CS}$  and  $\overline{WR}$  are low, the contents of the system data bus is latched into DBBIN. Also, the IBF flag is set and an interrupt is generated, if enabled.

#### **Command Write**

During any write (Table 2-4), the state of the  $A_0$  input is latched into the status register in the  $F_1$  (command/data) flag location. This additional bit is used to signal whether DBBIN contents are command ( $A_0 = 1$ ) or data ( $A_0 = 0$ ) information.

Inta

#### **INPUT/OUTPUT INTERFACE**

The UPI-41A/41AH/42/42AH has 16 lines for input and output functions. These I/O lines are grouped as two 8-bit TTL compatible ports: PORTS 1 and 2. The port lines can individually function as either inputs or outputs under software control. In addition, the lower 4 lines of PORT 2 can be used to interface to an 8243 I/O expander device to increase I/O capacity to 28 or more lines. The additional lines are grouped as 4-bit ports: PORTS 4, 5, 6, and 7.

#### PORTS 1 and 2

PORTS 1 and 2 are each 8 bits wide and have the same I/O characteristics. Data written to these ports by an

OUTL Pp,A instruction is latched and remains unchanged until it is rewritten. Input data is sampled at the time the IN, A, Pp instruction is executed. Therefore, input data must be present at the PORT until read by an INput instruction. PORT 1 and 2 inputs are fully TTL compatible and outputs will drive one standard TTL load.

#### **Circuit Configuration**

The PORT 1 and 2 lines have a special output structure (shown in Figure 2-18) that allows each line to serve as an input, an output, or both, even though outputs are statically latched.

Each line has a permanent high impedance pull-up (50 K $\Omega$ ) which is sufficient to provide source current for a TTL high level, yet can be pulled low by a standard TTL gate drive. Whenever a "1" is written to a line, a low impedance pull-up (250 $\Omega$ ) is switched in momentarily (500 ns) to provide a fast transition from 0 to 1. When a "0" is written to the line, a low impedance pull-down (300 $\Omega$ ) is active to provide TTL current sinking capability.

To use a particular PORT pin as an input, a logic "1" must first be written to that pin.



NOTE:

A RESET initializes all PORT pins to the high impedance logic "1" state.

#### UPI-41A/41AH/42/42AH USER'S MANUAL

An external TTL device connected to the pin has sufficient current sinking capability to pull-down the pin to the low state. An IN A, Pp instruction will sample the status of PORT pin and will input the proper logic level. With no external input connected, the IN A,Pp instruction inputs the previous output status.

This structure allows input and output information on the same pin and also allows any mix of input and output lines on the same port. However, when inputs and outputs are mixed on one PORT, a PORT write will cause the strong internal pull-ups to turn on at all inputs. If a switch or other low impedance device is connected to an input, a PORT write ("1" to an input) could cause current limits on internal lines to be exceeded. Figure 2-19 illustrates the recommended connection when inputs and outputs are mixed on one PORT.

The bidirectional port structure in combination with the UPI-41A/41AH/42/42AH logical AND and OR instructions provide an efficient means for handling single line inputs and outputs within an 8-bit processor.

#### PORTS 4, 5, 6, and 7

By using an 8243 I/O expander, 16 additional I/O lines can be connected to the UPI-41AH, 42AH and directly addressed as 4-bit I/O ports using UPI-41AH, 42AH

Figure 2-18. Quasi-Bidirectional Port Structure



instructions. This feature saves program space and design time, and improves the bit handling capability of the UPI-41A/41AH/42/42AH.

The lower half of PORT 2 provides an interface to the 8243 as illustrated in Figure 2-20. The PROG pin is used as a strobe to clock address and data information via the PORT 2 interface. The extra 16 I/O lines are referred to in UPI software as PORTS 4, 5, 6, and 7. Each PORT can be directly addressed and can be ANDed and ORed with an immediate data mask. Data can be moved directly to the accumulator from the expander PORTS (or vice-versa).

The 8243 I/O ports, PORTS 4, 5, 6, and 7, provide more drive capability than the UPI-41A/41AH/42/42AH bidirectional ports. The 8243 output is capable of driving about 5 standard TTL loads.

Multiple 8243's can be connected to the PORT 2 interface. In normal operation, only one of the 8243's would be active at the time an Input or Output command is executed. The upper half of PORT 2 is used to provide chip select signals to the 8043's. Figure 2-21 shows how four 8243's could be connected. Software is needed to select and set the proper PORT 2 pin before an INPUT or OUTPUT command to PORTS 4–7 is executed. In general, the software overhead required is very minor compared to the added flexibility of having a large number of I/O pins available.



Figure 2-19. Recommended PORT Input Connections

#### UPI-41A/41AH/42/42AH USER'S MANUAL



Figure 2-20. 8243 Expander Interface



Figure 2-21. Multiple 8243 Expansion



#### CHAPTER 3 INSTRUCTION SET

The UPI-41A/41AH/42/42AH Instruction Set is opcode-compatible with the MCS-48 set except for the elimination of external program and data memory instructions and the addition of the data bus buffer instructions. It is very straightforward and efficient in its use of program memory. All instructions are either 1 or 2 bytes in length (over 70% are only 1 byte long) and over half of the instructions execute in one machine cycle. The remainder require only two cycles and include Branch, Immediate, and I/O operations.

The UPI-41A/41AH/42/42AH Instruction Set efficiently handles the single-bit operations required in control applications. Special instructions allow port bits to be set or cleared individually. Also, any accumulator bit can be directly tested via conditional branch instructions. Additional instructions are included to simplify loop counters, table look-up routines and N-way branch routines.

The UPI-41A/41AH/42/42AH Microcomputer handles arithmetic operations in both binary and BCD for efficient interface to peripherals such as keyboards and displays.

The instruction set can be divided into the following groups:

- · Data Moves
- Accumulator Operations
- Flags
- Register Operations
- Branch Instructions
- Control
- Timer Operations
- Subroutines
- Input/Output Instructions

#### Data Moves (See Instruction Summary)

The 8-bit accumulator is the control point for all data transfers within the UPI-41A/41AH/42/42AH. Data can be transferred between the 8 registers of each working register bank and the accumulator directly (i.e., with a source or destination register specified by 3 bits in the instruction). The remaining locations in the RAM array are addressed either by  $R_0$  or  $R_1$  of the active register bank. Transfers to and from RAM require one cycle.

Constants stored in Program Memory can be loaded directly into the accumulator or the eight working registers. Data can also be transferred directly between the accumulator and the on-board timer/counter, the Status Register (STS), or the Program Status Word (PSW). Transfers to the STS register alter bits 4-7 only. Transfers to the PSW alter machine status accordingly and provide a means of restoring status after an interrupt or of altering the stack pointer if necessary.

#### Accumulator Operations

Immediate data, data memory, or the working registers can be added (with or without carry) to the accumulator. These sources can also be ANDed, ORed, or exclusive ORed to the accumulator. Data may be moved to or from the accumulator and working registers or data memory. The two values can also be exchanged in a single operation.

The lower 4 bits of the accumulator can be exchanged with the lower 4 bits of any of the internal RAM locations. This operation, along with an instruction which swaps the upper and lower 4-bit halves of the accumulator, provides easy handling of BCD numbers and other 4-bit quantities. To facilitate BCD arithmetic a Decimal Adjust instruction is also included. This instruction is used to correct the result of the binary addition of two 2-digit BCD numbers. Performing a decimal adjust on the result in the accumulator produces the desired BCD result.

The accumulator can be incremented, decremented, cleared, or complemented and can be rotated left or right 1 bit at a time with or without carry.

A subtract operation can be easily implemented in UPI software using three single-byte, single-cycle instructions. A value can be subtracted from the accumulator by using the following instructions:

- · Complement the accumulator
- Add the value to the accumulator
- Complement the accumulator

#### Flags

There are four user accessible flags:

- Carry
- Auxiliary Carry
- F<sub>0</sub>
- F<sub>1</sub>

The Carry flag indicates overflow of the accumulator, while the Auxiliary Carry flag indicates overflow between BCD digits and is used during decimal adjust

operations. Both Carry and Auxiliary Carry are part of the Program Status Word (PSW) and are stored in the stack during subroutine calls. The  $F_0$  and  $F_1$  flags are general-purpose flags which can be cleared or complemented by UPI instructions.  $F_0$  is accessible via the Program Status Word and is stored in the stack with the Carry flags.  $F_1$  reflects the condition of the  $A_0$  line, and caution must be used when setting or clearing it.

#### **Register Operations**

The working registers can be accessed via the accumulator as explained above, or they can be loaded with immediate data constants from program memory. In addition, they can be incremented or decremented directly, or they can be used as loop counters as explained in the section on branch instructions.

Additional Data Memory locations can be accessed with indirect instructions via  $R_0$  and  $R_1$ .

#### **Branch Instructions**

The UPI-41A/41AH/42/42AH Instruction Set includes 17 jump instructions. The unconditional allows jumps anywhere in the 1K words of program memory. All other jump instructions are limited to the current page (256 words) of program memory.

Conditional jump instructions can test the following inputs and maching flags:

- TEST 0 input pin
- TEST 1 input pin
- Input Buffer Full flag
- Output Buffer Full flag
- Timer flag
- Accumulator zero
- Accumulator bit
- Carry flag
- F<sub>0</sub> flag
- F<sub>1</sub> flag

The conditions tested by these instructions are the instantaneous values at the time the conditional jump instruction is executed. For instance, the jump on accumulator zero instruction tests the accumulator itself, not an intermediate flag.

The decrement register and jump if not zero (DJNZ) instruction combines decrement and branch operations

#### UPI-41A/41AH/42/42AH USER'S MANUAL

in a single instruction which is useful in implementing a loop counter. This instruction can designate any of the 8 working registers as a counter and can effect a branch to any address within the current page of execution.

A special indirect jump instruction (JMPP @A) allows the program to be vectored to any one of several different locations based on the contents of the accumulator. The contents of the accumulator point to a location in program memory which contains the jump address. As an example, this instruction could be used to vector to any one of several routines based on an ASCII character which has been loaded into the accumulator. In this way, ASCII inputs can be used to initiate various routines.

#### Control

The UPI-41A/41AH/42/42AH Instruction Set has six instructions for control of the DMA, interrupts, and selection of working registers banks.

The UPI-41A/41AH/42/42AH provides two instructions for control of the external microcomputer system. IBF and OBF flags can be routed to PORT 2 allowing interrupts of the external processor. DMA handshaking signals can also be enabled using lines from PORT 2.

The IBF interrupt can be enabled and disabled using two instructions. Also, the interrupt is automatically disabled following a **RESET** input or during an interrupt service routine.

The working register bank switch instructions allow the programmer to immediately substitute a second 8 register bank for the one in use. This effectively provides either 16 working registers or the means for quickly saving the contents of the first 8 registers in response to an interrupt. The user has the option of switching register banks when an interrupt occurs. However, if the banks are switched, the original bank will automatically be restored upon execution of a return and restore status (RETR) instruction at the end of the interrupt service routine.

#### Timer

The 8-bit on-board timer/counter can be loaded or read via the accumulator while the counter is stopped or while counting.

The counter can be started as a timer with an internal clock source or as an event counter or timer with an

external clock applied to the TEST 1 pin. The instruction executed determines which clock source is used. A single instruction stops the counter whether it is operating with an internal or an external clock source. In addition, two instructions allow the timer interrupt to be enabled or disabled.

#### **Subroutines**

Subroutines are entered by executing a call instruction. Calls can be made to any address in the 1K word program memory. Two separate return instructions determine whether or not status (i.e., the upper 4 bits of the PSW) is restored upon return from a subroutine.

#### Input/Output Instructions

Two 8-bit data bus buffer registers (DBBIN and DBBOUT) and an 8-bit status register (STS) enable the UPI-41A universal peripheral interface to communicate with the external microcomputer system. Data can be INputted from the DBBIN register to the accumulator. Data can be OUTputted from the accumulator to the DBBOUT register.

The STS register contains four user-definable bits  $(ST_4-ST_7)$  plus four reserved status bits (IBF, OBF, F<sub>0</sub> and F<sub>1</sub>). The user-definable bits are set from the accumulator.

The UPI-41A/41AH/42/42AH peripheral interface has two 8-bit static I/O ports which can be loaded to and from the accumulator. Outputs are statically latched but inputs to the ports are sampled at the time an IN instruction is executed. In addition, immediate data from program memory can be ANDed and ORed directly to PORTS 1 and 2 with the result remaining on the port. This allows "masks" stored in program memory to be used to set or reset individual bits on the I/O ports. PORTS 1 and 2 are configured to allow input on a given pin by first writing a "1" to the pin.

Four additional 4-bit ports are available through the 8243 I/O expander device. The 8243 interfaces to the



UPI-41A/41AH/42/42AH peripheral interface via four PORT 2 lines which form an expander bus. The 8243 ports have their own AND and OR instructions like the on-board ports, as well as move instructions to transfer data in or out. The expander AND or OR instructions, however, combine the contents of the accumulator with the selected port rather than with immediate data as is done with the on-board ports.

#### INSTRUCTION SET DESCRIPTION

The following section provides a detailed description of each UPI instruction and illustrates how the instructions are used.

For further information about programming the UPI, consult the 8048/8041AH Assembly Language Manual.

Table 3-1. Symbols and Abbreviations Used

| Symbol                          | Definition                               |
|---------------------------------|------------------------------------------|
| А                               | Accumulator                              |
| С                               | Carry                                    |
| DBBIN                           | Data Bus Buffer Input                    |
| DBBOUT                          | Data Bus Buffer Output                   |
| F <sub>0</sub> , F <sub>1</sub> | FLAG 0, FLAG 1 (C/D flag)                |
| I                               | Interrupt                                |
| Р                               | Mnemonic for "in-page" operation         |
| PC                              | Program Counter                          |
| Рр                              | Port designator ( $p = 1, 2, or 4-7$ )   |
| PSW                             | Program Status Word                      |
| Rr                              | Register designator ( $r = 0-7$ )        |
| SP                              | Stack Pointer                            |
| STS                             | Status register                          |
| Т                               | Timer                                    |
| TF                              | Timer Flag                               |
| Τ <sub>0</sub> , Τ <sub>1</sub> | TEST 0, TEST 1                           |
| #                               | Immediate data prefix                    |
| @                               | Indirect address prefix                  |
| (( ))                           | Double parentheses show the effect of @, |
|                                 | that is @RO is shown as ((RO)).          |
| ()                              | Contents of                              |

#### UPI-41A/41AH/42/42AH USER'S MANUAL

#### Table 3-2. Instruction Set Summary

| Mnemonic          | Description                       | Bytes | Cycle |
|-------------------|-----------------------------------|-------|-------|
| ACCUMULATOR       | 1                                 |       |       |
| ADD A, Rr         | Add register to A                 | 1     | 1     |
| ADD A, @Rr        | Add data memory to A              | 1     | 1     |
| ADD A, #data      | Add immediate to A                | 2     | 2     |
| ADDC A, Rr        | Add register to A with carry      | 1     | 1     |
| ADDC A, @Rr       | Add data memory to A              |       |       |
| ADDO A, CHI       | with carry                        | 1     | 1     |
|                   |                                   |       | '     |
| ADDC A,           | Add immediate to A                | 0     | 0     |
| #data             | with carry                        | 2     | 2     |
| ANL A, Rr         | And register to A                 | 1     | 1     |
| ANL A, @Rr        | And data memory to A              | 1     | 1     |
| ANL A, #data      | And immediate to A                | 2     | 2     |
| ORL A, Rr         | Or register to A                  | 1     | 1     |
| ORL A, @Rr        | Or data memory to A               | 1     | 1     |
| ORL A, #data      | Or immediate to A                 | 2     | 2     |
| XRL A, Rr         | Exclusive Or                      |       |       |
|                   | register to A                     | 1     | 1     |
| XRL A, @Rr        | Exclusive Or data                 |       |       |
| ,                 | memory to A                       | 1     | 1     |
| XRL A, #data      | Exclusive Or                      |       |       |
| Juliz July & data | immediate to A                    | 2     | 2     |
| INC A             | Increment A                       | 1     | 1     |
| DEC A             | Decrement A                       | 1     | 1     |
|                   | Clear A                           | 1     | 1     |
| CLR A             |                                   |       |       |
| CPL A             | Complement A                      | 1     | 1     |
| DAA               | Decimal Adjust A                  | 1     | 1     |
| SWAP A            | Swap nibbles of A                 | 1     | 1     |
| RL A              | Rotate A left                     | 1     | 1     |
| RLC A             | Rotate A left                     |       |       |
|                   | through carry                     | 1     | 1     |
| RR A              | Rotate A right                    | 1     | 1     |
| RRC A             | Rotate A right                    |       |       |
|                   | through carry                     | 1     | 1     |
| INPUT/OUTPUT      |                                   |       |       |
| IN A, Pp          | Input port to A                   | 1     | 2     |
| OUTL Pp, A        | Output A to port                  | 1     | 2     |
| ANL Pp, #data     | And immediate to port             | 2     | 2     |
| ORL Pp, #data     | •                                 | 2     | 2     |
|                   | Or immediate to port              |       | _     |
| IN A,DBB          | Input DDB to A, clear IBF         | 1     | 1     |
| OUT DBB, A        | Output A to DBB, Set OBF          | 1     | 1     |
| MOV STS,A         | $A_4 - A_7$ to bits 4-7 of status |       | 1     |
| MOVD A,Pp         | Input Expander port to A          | 1     | 2     |
| MOVD Pp,A         | Output A to Expander port         | 1     | 2     |
| ANLD Pp,A         | And A to Expander port            | 1     | 2     |
| ORLD Pp,A         | Or A to Expander port             | 1     | 2     |
| DATA MOVES        |                                   |       |       |
| MOV A, Rr         | Move register to A                | 1     | 1     |
| MOV A, @Rr        | Move data memory to A             | 1     | 1     |
| MOV A, #data      | Move immediate to A               | 2     | 2     |
| MOV Rr, A         | Move A to register                | 1     | 1     |
| · ·               | •                                 |       | -     |
| MOV @Rr, A        | Move A to data memory             | 1     | 1     |
| MOV Rr, #data     | Move immediate to register        | 2     | 2     |
| MOV @Rr,          | Move immediate to                 | ~     | ~     |
| #data             | data memory                       | 2     | 2     |
| MOV A, PSW        | Move PSW to A                     | 1     | 1     |
| MOV PSW, A        | Move A to PSW                     | 1     | 1     |
| XCH A, Rr         | Exchange A and registers          | 1     | 1     |
| XCH A, @Rr        | Exchange A and                    |       |       |
|                   | data memory                       | 1     | 1     |
| XCHD A,           | Exchange digit of A               |       |       |
| @Rr               | and register                      | 1     | 1     |
| ι                 | ~                                 |       |       |

| n Set Summa                                                             | iry                                                                                                                                                                                                                                                  |                       |                       |
|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------|
| Mnemonic                                                                | Description                                                                                                                                                                                                                                          | Bytes                 | Cycle                 |
| DATA MOVES                                                              | G (Continued)                                                                                                                                                                                                                                        |                       |                       |
| MOVP A, @A                                                              | Move to A from current                                                                                                                                                                                                                               |                       |                       |
|                                                                         | page                                                                                                                                                                                                                                                 | 1                     | 2                     |
| MOVP3 A,                                                                | Move to A from page 3                                                                                                                                                                                                                                | 1                     | 2                     |
| @A                                                                      |                                                                                                                                                                                                                                                      |                       |                       |
| TIMER/COUN                                                              |                                                                                                                                                                                                                                                      |                       |                       |
| MOV A,T                                                                 | Read Timer/Counter                                                                                                                                                                                                                                   | 1                     | 1                     |
| MOV T,A                                                                 | Load Timer/Counter                                                                                                                                                                                                                                   | 1                     | 1                     |
| STRT T                                                                  | Start Timer                                                                                                                                                                                                                                          | 1                     | 1                     |
| STRT CNT                                                                | Start Counter                                                                                                                                                                                                                                        | 1                     | 1                     |
| STOP TCNT<br>EN TCNTI                                                   | Stop Timer/Counter<br>Enable Timer/Counter                                                                                                                                                                                                           | 1<br>1                | 1<br>1                |
| DIS TCNTI                                                               | Disable Timer/Counter                                                                                                                                                                                                                                | 1                     | 1                     |
| DIG TOINIT                                                              | Interrupt                                                                                                                                                                                                                                            |                       |                       |
|                                                                         | intorrupt                                                                                                                                                                                                                                            |                       |                       |
| CONTROL                                                                 | Enchle DMA Llandobaka                                                                                                                                                                                                                                |                       |                       |
| EN DMA                                                                  | Enable DMA Handshake<br>Lines                                                                                                                                                                                                                        | 1                     | 1                     |
| EN I                                                                    | Enable IBF interrupt                                                                                                                                                                                                                                 | 1                     | 1                     |
| DISI                                                                    | Disable IBF interrupt                                                                                                                                                                                                                                | 1                     | 1                     |
| EN FLAGS                                                                | Enable Master Interrupts                                                                                                                                                                                                                             | 1                     | 1                     |
| SEL RB0                                                                 | Select register bank 0                                                                                                                                                                                                                               | 1                     | 1                     |
| SEL RB1                                                                 | Select register bank 1                                                                                                                                                                                                                               | 1                     | 1                     |
| NOP                                                                     | No Operation                                                                                                                                                                                                                                         | 1                     | 1                     |
| REGISTERS                                                               | · · ·                                                                                                                                                                                                                                                |                       |                       |
| INC Rr                                                                  | Increment register                                                                                                                                                                                                                                   | 1                     | 1                     |
| INC @Rr                                                                 | Increment data memory                                                                                                                                                                                                                                | 1                     | 1                     |
| DEC Rr                                                                  | Decrement register                                                                                                                                                                                                                                   | 1                     | 1                     |
| SUBROUTINE                                                              |                                                                                                                                                                                                                                                      |                       |                       |
| CALL addr                                                               | -<br>Jump to subroutine                                                                                                                                                                                                                              | 2                     | 2                     |
| RET                                                                     | Return                                                                                                                                                                                                                                               | 1                     | 2                     |
| RETR                                                                    | Return and restore status                                                                                                                                                                                                                            | 1                     | 2                     |
| FLAGS                                                                   |                                                                                                                                                                                                                                                      |                       |                       |
| CLR C                                                                   | Clear Carry                                                                                                                                                                                                                                          | 1                     | 1                     |
| CPL C                                                                   | Complement Carry                                                                                                                                                                                                                                     | 1                     | 1                     |
| CLR F0                                                                  | Clear Flag 0                                                                                                                                                                                                                                         | 1                     | 1                     |
| CPL F0                                                                  | Complement Flag 0                                                                                                                                                                                                                                    | 1                     | 1                     |
| CLR F1                                                                  | Clear F <sub>1</sub> Flag                                                                                                                                                                                                                            | 1                     | 1                     |
| CPL F1                                                                  | Complement F1 Flag                                                                                                                                                                                                                                   | 1                     | 1                     |
| BRANCH                                                                  |                                                                                                                                                                                                                                                      |                       |                       |
| JMP addr                                                                | Jump unconditional                                                                                                                                                                                                                                   | 2                     | 2                     |
| JMPP @A                                                                 | Jump indirect                                                                                                                                                                                                                                        | 1                     | 2                     |
| DJNZ Rr,                                                                | Decrement register                                                                                                                                                                                                                                   |                       |                       |
| addr                                                                    | and jump on non-zero                                                                                                                                                                                                                                 | 2                     | 2                     |
| JC addr                                                                 | Jump on Carry $= 1$                                                                                                                                                                                                                                  | 2                     | 2                     |
| JNC addr                                                                | Jump on Carry $= 0$                                                                                                                                                                                                                                  | 2                     | 2                     |
| JZ addr                                                                 | Jump on A zero                                                                                                                                                                                                                                       | 2                     | 2                     |
| JNZ addr                                                                | Jump on A not zero                                                                                                                                                                                                                                   | 2                     | 2                     |
| JT0 addr                                                                | Jump on $T_0 = 1$                                                                                                                                                                                                                                    | 2                     | 2                     |
|                                                                         | Jump on $T_0 = 0$                                                                                                                                                                                                                                    | 2                     | 2                     |
| JNT0 addr                                                               |                                                                                                                                                                                                                                                      |                       |                       |
| JT1 addr                                                                | Jump on $T_1 = 1$                                                                                                                                                                                                                                    | 2                     | 2                     |
| JT1 addr<br>JNT1 addr                                                   | $\begin{array}{l} \text{Jump on } T_1 = 1 \\ \text{Jump on } T_1 = 0 \end{array}$                                                                                                                                                                    | 2                     | 2                     |
| JT1 addr<br>JNT1 addr<br>JF0 addr                                       | $\begin{array}{l} Jump \text{ on } T_1 = 1 \\ Jump \text{ on } T_1 = 0 \\ Jump \text{ on } F_0 \text{ Flag} = 1 \end{array}$                                                                                                                         | 2<br>2                | 2<br>2                |
| JT1 addr<br>JNT1 addr<br>JF0 addr<br>JF1 addr                           | $\begin{array}{l} \text{Jump on } T_1 = 1 \\ \text{Jump on } T_1 = 0 \\ \text{Jump on } F_0 \ \text{Flag} = 1 \\ \text{Jump on } F_1 \ \text{Flag} = 1 \end{array}$                                                                                  | 2<br>2<br>2           | 2<br>2<br>2           |
| JT1 addr<br>JNT1 addr<br>JF0 addr<br>JF1 addr<br>JTF addr               | $\begin{array}{l} \text{Jump on } T_1 = 1 \\ \text{Jump on } T_1 = 0 \\ \text{Jump on } F_0  \text{Flag} = 1 \\ \text{Jump on } F_1  \text{Flag} = 1 \\ \text{Jump on Timer } \text{Flag} = 1 \end{array}$                                           | 2<br>2<br>2<br>2      | 2<br>2<br>2<br>2      |
| JT1 addr<br>JNT1 addr<br>JF0 addr<br>JF1 addr<br>JTF addr<br>JNIBF addr | $\begin{array}{l} Jump \text{ on } T_1 = 1\\ Jump \text{ on } T_1 = 0\\ Jump \text{ on } F_0 \mbox{ Flag} = 1\\ Jump \text{ on } F_1 \mbox{ Flag} = 1\\ Jump \text{ on } Timer \mbox{ Flag} = 1\\ Jump \text{ on } IBF \mbox{ Flag} = 0 \end{array}$ | 2<br>2<br>2<br>2<br>2 | 2<br>2<br>2<br>2<br>2 |
| JT1 addr<br>JNT1 addr<br>JF0 addr<br>JF1 addr<br>JTF addr               | $\begin{array}{l} \text{Jump on } T_1 = 1 \\ \text{Jump on } T_1 = 0 \\ \text{Jump on } F_0  \text{Flag} = 1 \\ \text{Jump on } F_1  \text{Flag} = 1 \\ \text{Jump on Timer } \text{Flag} = 1 \end{array}$                                           | 2<br>2<br>2<br>2      | 2<br>2<br>2<br>2      |



#### ALPHABETIC LISTING

| Opcode:        | 0 1 1 0 1 r <sub>2</sub> r <sub>1</sub> r <sub>0</sub>                |                                                                   |
|----------------|-----------------------------------------------------------------------|-------------------------------------------------------------------|
|                | The contents of register 'r' are add<br>(A) $\leftarrow$ (A) + (Rr)   | led to the accumulator. Carry is affected.<br>r = 0-7             |
| Example:       | ADDREG: ADD A,R6                                                      | ;ADD REG 6 CONTENTS<br>;TO ACC                                    |
| DD A,@Rr Add   | Data Memory Contents to Accu                                          | nulator                                                           |
| Opcode:        | 0110 000r                                                             |                                                                   |
|                | The contents of the standard data to the accumulator. Carry is affect | memory location address by register 'r' bits $0-7$ are adde ted.  |
|                | $(A) \leftarrow (A) + ((Rr))$                                         | r = 0-1                                                           |
| Example:       | ADDM: MOV RO,#47<br>ADD A,@RO                                         | ;MOVE 47 DECIMAL TO REG 0<br>;ADD VALUE OF LOCATION<br>;47 TO ACC |
| DD A, # data A | dd Immediate Data to Accumulat                                        | or                                                                |
| Opcode:        | 0000 0011 • d;                                                        | $d_{6} d_{5} d_{4} d_{3} d_{2} d_{1} d_{0}$                       |
|                | This is a 2-cycle instruction. The s<br>(A) $\leftarrow$ (A) + data   | pecified data is added to the accumulator. Carry is affected      |
| Example:       | ADDID: ADD A, #ADDER                                                  | ;ADD VALUE OF SYMBOL<br>;ADDER' TO ACC                            |
| DDC A,Rr Add   | Carry and Register Contents to                                        | Accumulator                                                       |
| Opcode:        | 0 1 1 1 1 r <sub>2</sub> r <sub>1</sub> r <sub>0</sub>                |                                                                   |
|                | The content of the carry bit is add                                   | ed to accumulator location 0. The contents of register 'r' ar     |

The content of the carry bit is added to accumulator location 0. The contents of register 'r' are then added to the accumulator. Carry is affected. (A)  $\leftarrow$  (A) + (Rr) + (C) r = 0-7

**Example:** ADDRGC: ADDC A,R4

;ADD CARRY AND REG 4 ;CONTENTS TO ACC

| ADDC A,@Rr Ad   | d Carry and Data Memory Conten                                                                                                                              | ts to Accumulator                                                                                                             |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| Opcode:         | 0 1 1 1 0 0 0 r                                                                                                                                             |                                                                                                                               |
|                 |                                                                                                                                                             | ded to accumulator location 0. Then the contents of the ressed by register 'r' bits 0–7 are added to the accumulatr $r = 0-1$ |
| Example:        | ADDMC: MOV R1,#40<br>ADDC A,@R1                                                                                                                             | ;MOV '40' DEC TO REG 1<br>;ADD CARRY AND LOCATION 40<br>;CONTENTS TO ACC                                                      |
| ADDC A, # data  | Add Carry and Immediate Data to A                                                                                                                           | Accumulator                                                                                                                   |
| Opcode:         | 0001 0011 • d <sub>7</sub>                                                                                                                                  | $d_6 d_5 d_4 d_3 d_2 d_1 d_0$                                                                                                 |
|                 | This is a 2-cycle instruction. The cc<br>Then the specified data is added to<br>(A) $\leftarrow$ (A) + data + (C)                                           | ontent of the carry bit is added to accumulator location 0.<br>the accumulator. Carry is affected.                            |
| Example:        | ADDC A, #255                                                                                                                                                | ;ADD CARRY AND '225' DEC<br>;TO ACC                                                                                           |
| ANL A,Rr Logica | al AND Accumulator With Register                                                                                                                            | Mask                                                                                                                          |
| Opcode:         | 0 1 0 1 1 r <sub>2</sub> r <sub>1</sub> r <sub>0</sub>                                                                                                      |                                                                                                                               |
|                 | Data in the accumulator is logically<br>(A) $\leftarrow$ (A) AND (Rr)                                                                                       | ANDed with the mask contained in working register 'r'. $r = 0-7$                                                              |
|                 |                                                                                                                                                             |                                                                                                                               |
| Example:        | ANDREG: ANL A,R3                                                                                                                                            | ;'AND' ACC CONTENTS WITH MASK<br>;MASK IN REG 3                                                                               |
| ·               | ANDREG: ANL A,R3                                                                                                                                            | ;MASK IN REG 3                                                                                                                |
| ·               |                                                                                                                                                             | ;MASK IN REG 3                                                                                                                |
| ANL A,@Rr Logi  | cal AND Accumulator With Memor                                                                                                                              | ;MASK IN REG 3 ry Mask ly ANDed with the mask contained in the data memory                                                    |
| ANL A,@Rr Logi  | cal AND Accumulator With Memor         0       1       0       0       r         Data in the accumulator is logicall location referenced by register 'r', b | MASK IN REG 3<br><b>ry Mask</b><br>ly ANDed with the mask contained in the data memory<br>its 0-7.                            |



| ANL A, # data Lo                  | gical AND                                                                                                     | Accum                                          | nulator                                               | With Im                     | mediate Ma                                     | sk                                                                                                               |                       |
|-----------------------------------|---------------------------------------------------------------------------------------------------------------|------------------------------------------------|-------------------------------------------------------|-----------------------------|------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-----------------------|
| Opcode:                           | 010                                                                                                           | 1 0                                            | 011                                                   | • d                         | 7 d <sub>6</sub> d <sub>5</sub> d <sub>4</sub> | $d_3 \; d_2 \; d_1 \; d_0$                                                                                       | ]                     |
|                                   | This is a<br>ly-specific<br>(A) ←                                                                             | ed mask                                        |                                                       | on. Data                    | in the accun                                   | nulator is logicall                                                                                              | y ANDed with an immed |
| Example:                          | ANDID:                                                                                                        | ANL A                                          | A,#0AF                                                | н                           | ;'AN                                           | D' ACC CONTE                                                                                                     | NTS                   |
|                                   |                                                                                                               |                                                |                                                       |                             | ;WIT                                           | H MASK 10101                                                                                                     | 111                   |
|                                   |                                                                                                               | ANL A                                          | λ,#3+Σ                                                | K/Y                         |                                                | D' ACC CONTE                                                                                                     |                       |
|                                   |                                                                                                               |                                                |                                                       |                             |                                                | H VALUE OF E                                                                                                     | XP                    |
|                                   |                                                                                                               |                                                |                                                       |                             | •3+≯                                           | Κ/Υ'                                                                                                             |                       |
| NL PP,#data L<br>Opcode:<br>Note: | $\begin{array}{c} 1 & 0 & 0 \\ \hline \\ This is a \\ specified \\ (Pp) \leftarrow \\ Bits & 0-1 \end{array}$ | 1 1<br>2-cycle<br>mask.<br>(Pp) A<br>of the op | 0 p <sub>1</sub> p <sub>0</sub><br>instruct<br>ND dat | ion. Data<br>a<br>e used to | $d_7 d_6 d_5 d_7$<br>a on the port<br>p = 1    | $\begin{array}{c c} 4 & d_3 & d_2 & d_1 & d_2 \\ t 'p' is logically & d_1 \\ 1-2 \\ 0 RT 1 and PORT \end{array}$ | ANDed with an immedia |
|                                   | Bits                                                                                                          | p1                                             | 0q                                                    | Port                        |                                                |                                                                                                                  |                       |
|                                   |                                                                                                               | •                                              |                                                       |                             | -                                              |                                                                                                                  |                       |
|                                   |                                                                                                               | 0                                              | 0                                                     | X                           |                                                |                                                                                                                  |                       |
|                                   |                                                                                                               | 0                                              |                                                       | 1                           |                                                |                                                                                                                  |                       |
|                                   |                                                                                                               |                                                | 0                                                     | 2                           |                                                |                                                                                                                  |                       |
|                                   |                                                                                                               | 1                                              | 1                                                     | X                           |                                                |                                                                                                                  |                       |
| Example:                          | ANDP2:                                                                                                        | ANL P                                          | 2,#OF0                                                | H                           |                                                | D' PORT 2 CON<br>'H MASK'F0' HI                                                                                  |                       |

#### ANL A. # data Logical AND Accumulator With Immediate Mask

ANLD Pp,A Logical AND Port 4–7 With Accumulator Mask

**Opcode:** 1001 11p<sub>1</sub>p<sub>0</sub>

This is a 2-cycle instruction. Data on port 'p' on the 8243 expander is logically ANDed with the digit mask contained in accumulator bits 0-3. (Pp)  $\leftarrow$  (Pp) AND (A0-3) p = 4-7

;(CLEAR P20-23)

**Note:** The mapping of Port 'p' to opcode bits p<sub>1</sub>, p<sub>0</sub> is as follows:

| 11 | 0  | 1 1  |
|----|----|------|
| P1 | P0 | Port |
| 0  | 0  | 4    |
| 0  | 1  | 5    |
| 1  | 0  | 6    |
| 1  | 1  | 7    |

**Example:** ANDP4: ANLD P4,A

;'AND' PORT 4 CONTENTS ;WITH ACC BITS 0–3

#### UPI-41A/41AH/42/42AH USER'S MANUAL

CALL address Subroutine Call Opcode: 0100 a<sub>10</sub> a<sub>9</sub> a<sub>8</sub> 1  $a_7 \ a_6 \ a_5 \ a_4$  $a_3 \ a_2 \ a_1 \ a_0$ This is a 2-cycle instruction. The program counter and PSW bits 4-7 are saved in the stack. The stack pointer (PSW bits 0-2) is updated. Program control is then passed to the location specified by 'address'. Execution continues at the instruction following the CALL upon return from the subroutine.  $((SP)) \leftarrow (PC), (PSW_{4-7})$  $(SP) \leftarrow (SP) + 1$  $(PC_{8-9}) \leftarrow (addr_{8-9})$  $(PC_{0-7}) \leftarrow (addr_{0-7})$ Example: Add three groups of two numbers. Put subtotals in locations 50, 51 and total in location 52. MOV R0, #50 ;MOVE '50' DEC TO ADDRESS ;REG 0 BEGADD: MOV A,R1 ;MOVE CONTENTS OF REG 1 ;TO ACC ADD A,R2 ;ADD REG 2 TO ACC CALL SUBTOT CALL SUBROUTINE 'SUBTOT' ADD A,R3 ;ADD REG 3 TO ACC ADD A,R4 ;ADD REG 4 TO ACC CALL SUBTOT CALL SUBROUTINE 'SUBTOT' ADD A,R5 ;ADD REG 5 TO ACC ADD A,R6 ADD REG 6 TO ACC CALL SUBTOT ;CALL SUBROUTINE 'SUBTOT' SUBTOT: MOV @R0,A ;MOVE CONTENTS OF ACC TO LOCATION ADDRESSED BY ;REG 0 INC R0 INCREMENT REG 0 RET ;RETURN TO MAIN PROGRAM

#### CLR A Clear Accumulator

Opcode: $0 \ 0 \ 1 \ 0$  $0 \ 1 \ 1 \ 1$ The contents of the accumulator are cleared to zero.(A) <-- 00H</th>

#### CLR C Clear Carry Bit

| Opcode: | 1001 | 0111 |                                                                                                                                |
|---------|------|------|--------------------------------------------------------------------------------------------------------------------------------|
|         | U    | 1 0  | execution, the carry bit can be set to one by the ADD, ADDC, RLC, instructions. This instruction resets the carry bit to zero. |

#### CLR F1 Clear Flag 1

**Opcode:**  $\begin{array}{c|c} 1 & 0 & 1 & 0 \\ \hline \\ The F_1 \ flag \ is \ cleared \ to \ zero. \\ (F_1) \longleftarrow 0 \end{array}$ 

CLR F0 Clear Flag 0



#### Opcode: 1000 0101 $\begin{array}{rrr} F_0 \text{ flag is cleared to zero.} \\ (F_0) & \longleftarrow & 0 \end{array}$ CPL A Complement Accumulator Opcode: 0011 0111 The contents of the accumulator are complemented. This is strictly a one's complement. Each one is changed to zero and vice-versa. (A) $\leftarrow$ NOT (A) Example: Assume accumulator contains 01101010. ;ACC CONTENTS ARE COMPLE-CPLA: CPL A MENTED TO 10010101 CPL C Complement Carry Bit 1010 0111 Opcode: The setting of the carry bit is complemented; one is changed to zero, and zero is changed to one. (C) $\leftarrow$ NOT (C) Example: Set C to one; current setting is unknown. CT01: CLR C ;C IS CLEARED TO ZERO CPL C C IS SET TO ONE

#### **CPL F0 COMPLEMENT FLAG 0**

**Opcode:**  $1 \ 0 \ 0 \ 1 \ 0 \ 1 \ 0 \ 1$ The setting of Flag 0 is complemented; one is changed to zero, and zero is changed to one.  $F_0 \leftarrow NOT (F0)$ 

#### CPL F1 Complement Flag 1

Opcode:

1011 0101

The setting of the  $F_1$  Flag is complemented; one is changed to zero, and zero is changed to one.  $(F_1) \leftarrow NOT(F_1)$ 

#### DA A Decimal Adjust Accumulator Opcode: 0101 0111 The 8-bit accumulator value is adjusted to form two 4-bit Binary Coded Decimal (BCD) digits following the binary addition of BCD numbers. The carry bit C is affected. If the contents of bits 0-3 are greater than nine, or if AC is one, the accumulator is incremented by six. The four high-order bits are then checked. If bits 4–7 exceed nine, or if C is one, these bits are increased by six. If an overflow occurs, C is set to one; otherwise, it is cleared to zero. Example: Assume accumulator contains 9AH. ;ACC ADJUSTED TO 01H with C set DA A ACC С AC 0 0 9AH INITIAL CONTENTS ADD SIX TO LOW DIGIT 06H 0 0 A1H ADD SIX TO HIGH DIGIT 60H 0 01H RESULT 1 DEC A Decrement Accumulator 0000 0111 Opcode: The contents of the accumulator are decremented by one. (A) $\leftarrow$ (A) - 1 Example: Decrement contents of data memory location 63. MOV R0,#3FH ;MOVE '3F' HEX TO REG 0 MOV A,@R0 MOVE CONTENTS OF LOCATION 63 ;TO ACC DECREMENT ACC DEC A MOV @R0,A ;MOVE CONTENTS OF ACC TO ;LOCATION 63 DEC Rr Decrement Register Opcode: 1100 1 r<sub>2</sub> r<sub>1</sub> r<sub>0</sub> The contents of working register 'r' are decremented by one. $(Rr) \leftarrow (Rr) - 1$ r = 0 - 7Example: DECR1: DEC R1 ;DECREMENT ADDRESS REG 1 DIS I Disable IBF Interrupt Opcode: 0001 0101 The input Buffer Full interrupt is disabled. The interrupt sequence is not initiated by $\overline{WR}$ and CS, however, an IBF interrupt request is latched and remains pending until an EN I (enable IBF interrupt) instruction is executed.

**Note:** The IBF flag is set and cleared independent of the IBF interrupt request so that handshaking protocol can continue normally.



| DIS TCNTI Disabl | le Timer/Counter Interrupt                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                             |  |  |  |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Opcode:          | 0 0 1 1 0 1 0 1<br>The timer/counter interrupt is disabled. Any pending timer interrupt request is cleared. Th interrupt sequence is not initiated by an overflow, but the timer flag is set and time accumula tion continues.                                                                         |                                                                                                                                                                                                                                                             |  |  |  |
| DJNZ Rr, address | Decrement Register and Test                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                             |  |  |  |
| Opcode:          | 1 1 1 0 1 r <sub>2</sub> r <sub>1</sub> r <sub>0</sub> •                                                                                                                                                                                                                                               | $a_7 a_6 a_5 a_4$ $a_3 a_2 a_1 a_0$                                                                                                                                                                                                                         |  |  |  |
|                  | contains all zeros, program con                                                                                                                                                                                                                                                                        | egister 'r' is decremented and tested for zero. If the register<br>trol falls through to the next instruction. If the register con-<br>s to the specified address within the current page.                                                                  |  |  |  |
| Note:            | A 10-bit address specification does not cause an error if the DJNZ instruction and the jump target are on the same page. If the DJNZ instruction begins in location 255 of a page, it will jump to a target address on the following page. Otherwise, it is limited to a jump within the current page. |                                                                                                                                                                                                                                                             |  |  |  |
| Example:         | Increment values in data memor<br>MOV R0, # 50<br>MOV R3, # 05<br>INCRT: INC @R0<br>INC R0<br>DJNZ R3, INCRT<br>NEXT                                                                                                                                                                                   | ;MOVE '50' DEC TO ADDRESS<br>;REG 0<br>;MOVE '5' DEC TO COUNTER<br>;REG 3<br>;INCREMENT CONTENTS OF<br>;LOCATION ADDRESSED BY<br>;REG 0<br>;INCREMENT ADDRESS IN REG 0<br>;DECREMENT REG 3—JUMP TO<br>;'INCRT' IF REG 3 NONZERO<br>;'NEXT' ROUTINE EXECUTED |  |  |  |
| EN DMA Enable [  | DMA Handshake Lines                                                                                                                                                                                                                                                                                    | ;IF R3 IS ZERO                                                                                                                                                                                                                                              |  |  |  |

Opcode:

1110 0101

DMA handshaking is enabled using  $P_{26}$  as DMA request (DRQ) and  $P_{27}$  as DMA acknowledge (DACK). The DACK lines forces  $\overline{CS}$  and  $A_0$  low internally and clears DRQ.

#### EN FLAGS Enable Master Interrupts

| Opcode: | 1 | 1 | 1 | 1 | 0101 |
|---------|---|---|---|---|------|

The Output Buffer Full (OBF) and the Input Buffer Full (IBF) flags (IBF is inverted) are routed to  $P_{24}$  and  $P_{25}$ . For proper operation, a "1" should be written to  $P_{25}$  and  $P_{24}$  before the EN FLAGS instruction. A "0" written to  $P_{24}$  or  $P_{25}$  disables the pin.

#### UPI-41A/41AH/42/42AH USER'S MANUAL

#### EN I Enable IBF Interrupt 0000 0101 Opcode: The Input Buffer Full interrupt is enabled. A low signal on $\overline{WR}$ and $\overline{CS}$ initiates the interrupt sequence. EN TCNTI Enable Timer/Counter Interrupt Opcode: 0010 0101 The timer/counter interrupt is enabled. An overflow of this register initiates the interrupt sequence. IN A,DBB Input Data Bus Buffer Contents to Accumulator Opcode: 0010 0010 Data in the DBBIN register is transferred to the accumulator and the Input Buffer Full (IBF) flag is set to zero. $(A) \leftarrow (DBB)$ $(IBF) \leftarrow 0$ Example: INDBB: IN A,DBB ;INPUT DBBIN CONTENTS TO ;ACCUMULATOR IN A,Pp Input Port 1-2 Data to Accumulator Opcode: $0000 | 10p_1p_0$ This is a 2-cycle instruction. Data present on port 'p' is transferred (read) to the accumulator. (A) $\leftarrow$ (Pp) p = 1-2 (see ANL instruction) Example: INP 12: IN A,P1 ;INPUT PORT 1 CONTENTS :TO ACC MOVE ACC CONTENTS TO MOV R6,A ;REG 6 INPUT PORT 2 CONTENTS IN A,P2 ;TO ACC MOV R7.A MOVE ACC CONTENTS TO REG 7 INC A Increment Accumulator Opcode: 0001 0111 The contents of the accumulator are incremented by one. (A) $\leftarrow$ (A) + 1 Example: Increment contents of location 10 in data memory.

Increment contents of location 10 in data memory. INCA: MOV R0, #10 ;MOV '10' DEC TO ADDRESS ;REG 0 MOV A,@R0 ;MOVE CONTENTS OF LOCATION ;10 TO ACC INC A ;INCREMENT ACC MOV @R0,A ;MOVE ACC CONTENTS TO ;LOCATION 10



| INC Rr Incremer | nt Register                                                                                                                                              |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Opcode:         | 0 0 0 1 1 r <sub>2</sub> r <sub>1</sub> r <sub>0</sub>                                                                                                   |
|                 | The contents of working register 'r' are incremented by one.<br>(Rr) $\leftarrow$ (Rr) + 1 $r = 0-7$                                                     |
| Example:        | INCR0: INC R0 ;INCREMENT ADDRESS REG 0                                                                                                                   |
| INC @Rr Increm  | ent Data Memory Location                                                                                                                                 |
| Opcode:         | 0 0 0 1 0 0 0 r                                                                                                                                          |
|                 | The contents of the resident data memory location addressed by register 'r' bits 0-7 are incremented by one.<br>$((Rr)) \leftarrow ((Rr)) + 1$ $r = 0-1$ |
| Example:        | INCDM: MOV R1,#OFFH ;MOVE ONES TO REG 1<br>INC @R1 ;INCREMENT LOCATION 63                                                                                |
| JBb address Ju  | np If Accumulator Bit is Set                                                                                                                             |
| Opcode:         | $\begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                   |
|                 | This is a 2-cycle instruction. Control passes to the specified address if accumulator bit 'b' is set to one.                                             |
|                 | $\begin{array}{ll} \text{(PC}_{0-7}) \text{ addr} & \text{if } b = 1 \\ \text{(PC)} \longleftarrow \text{(PC)} + 2 & \text{if } b = 0 \end{array}$       |
| Example:        | JB4IS1: JB4 NEXT ;JUMP TO 'NEXT' ROUTINE<br>;IF ACC BIT 4 = 1                                                                                            |
| JC address Jum  | p If Carry Is Set                                                                                                                                        |
| Opcode:         | 1 1 1 1 0 1 1 0 • a <sub>7</sub> a <sub>6</sub> a <sub>5</sub> a <sub>4</sub> a <sub>3</sub> a <sub>2</sub> a <sub>1</sub> a <sub>0</sub>                |
|                 | This is a 2-cycle instruction. Control passes to the specified address if the carry bit is set to                                                        |
|                 | one.<br>$(PC_{0-7}) \leftarrow addr$ if $C = 1$<br>$(PC) \leftarrow (PC) + 2$ if $C = 0$                                                                 |
| Example:        | JC1: JC OVERFLOW ;JUMP TO 'OVFLOW' ROUTINE<br>;IF $C = 1$                                                                                                |
| JF0 address Jur | np If Flag 0 is Set                                                                                                                                      |
| Opcode:         | 1011 0110 • a <sub>7</sub> a <sub>6</sub> a <sub>5</sub> a <sub>4</sub> a <sub>3</sub> a <sub>2</sub> a <sub>1</sub> a <sub>0</sub>                      |
|                 | This is a 2-cycle instruction. Control passes to the specified address if flag 0 is set to one.<br>$(PC_{0-7}) \leftarrow addr$ if $F_0 = 1$             |
| Example:        | JF0IS1: JF0 TOTAL ;JUMP TO 'TOTAL' ROUTINE ;IF $F_0 = 1$                                                                                                 |
|                 |                                                                                                                                                          |
|                 |                                                                                                                                                          |
|                 |                                                                                                                                                          |



JF1 address Jump If C/D Flag (F1) Is Set

#### 0110 Opcode: 0111 a<sub>7</sub> a<sub>6</sub> a<sub>5</sub> a<sub>4</sub> a<sub>3</sub> a<sub>2</sub> a<sub>1</sub> a<sub>0</sub> This is a 2-cycle instruction. Control passes to the specified address if the C/D flag (F1) is set to one. $(PC_{0-7}) \leftarrow addr$ if $F_1 = 1$ Example: JF 1IS1: JF1 FILBUF ;JUMP TO 'FILBUF' ;ROUTINE IF $F_1 = 1$ JMP address Direct Jump Within 1K Block 0100 Opcode: $a_{10} a_9 a_8 0$ ٠ $a_7 a_6 a_5 a_4$ a<sub>3</sub> a<sub>2</sub> a<sub>1</sub> a<sub>0</sub> This is a 2-cycle instruction. Bits 0-10 of the program counter are replaced with the directlyspecified address. $(PC_{8-10}) \leftarrow addr 8-10$ $(PC_{0-7}) \leftarrow addr 0-7$ JMP SUBTOT ;JUMP TO SUBROUTINE 'SUBTOT' Example: JMP \$-6 JUMP TO INSTRUCTION SIX LOCATIONS BEFORE CURRENT LOCATION JMP 2FH ;JUMP TO ADDRESS '2F' HEX JMPP @A Indirect Jump Within Page 1011 0011 Opcode: This is a 2-cycle instruction. The contents of the program memory location pointed to by the accumulator are substituted for the 'page' portion of the program counter (PC 0-7). $(PC_{0-7}) \leftarrow ((A))$ Example: Assume accumulator contains OFH JMPPAG: JMPP @A JMP TO ADDRESS STORED IN LOCATION 15 IN CURRENT PAGE JNC address Jump If Carry Is Not Set Opcode: 1110 0110 ٠ a<sub>7</sub> a<sub>6</sub> a<sub>5</sub> a<sub>4</sub> a<sub>3</sub> a<sub>2</sub> a<sub>1</sub> a<sub>0</sub> This is a 2-cycle instruction. Control passes to the specified address if the carry bit is not set, that is, equals zero. $(PC_{0-7}) \leftarrow addr$ if C = 0JC0: JNC NOVFLO JUMP TO 'NOVFLO' ROUTINE Example: ;IF C = 0

JNIBF address Jump If Input Buffer Full Flag Is Low

| Opcode:  | 1 1 0 1 0 1 1 0 • a <sub>7</sub> a <sub>6</sub> a                                                               | $a_5 a_4 = a_3 a_2 a_1 a_0$                                             |
|----------|-----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
|          | This is a 2-cycle instruction. Control partial flag is low (IBF = 0).<br>(PC <sub>0-7</sub> ) $\leftarrow$ addr | asses to the specified address if the Input Buffer Full<br>if $IBF = 0$ |
| Example: | LOC 3:JNIBF LOC 3                                                                                               | ;JUMP TO SELF IF IBF = 0<br>;OTHERWISE CONTINUE                         |
|          |                                                                                                                 |                                                                         |



| JNTO address   | Jump if TEST 0 is Low                                                                                                                                                                                                                                                                                                                                                      |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Opcode:        | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                      |
|                | This is a 2-cycle instruction. Control passes to the specified address, if the TEST 0 signal is low. Pin is sampled during SYNC.<br>$(PC_{0-7}) \leftarrow addr$ if $T_0 = 0$                                                                                                                                                                                              |
| Example:       | JT0LOW: JNT0 60 ;JUMP TO LOCATION 60 DEC ;IF $T_0 = 0$                                                                                                                                                                                                                                                                                                                     |
| JNT1 address   | lump If TEST 1 is Low                                                                                                                                                                                                                                                                                                                                                      |
| Opcode:        | $\begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                                                                                                                                                                                     |
|                | This is a 2-cycle instruction. Control passes to the specified address if the TEST 1 signal is low.<br>Pin is sampled during SYNC.<br>$(PC_{0-7}) \leftarrow addr$ if $T_1 = 0$                                                                                                                                                                                            |
| Example:       | JT1LOW: JNT1 OBBH ;JUMP TO LOCATION 'BB' HEX ;IF $T_1 = 0$                                                                                                                                                                                                                                                                                                                 |
| JNZ address Ju | Imp If Accumulator Is Not Zero                                                                                                                                                                                                                                                                                                                                             |
| Opcode:        | $1 0 0 1 0 1 1 0 \bullet a_7 a_6 a_5 a_4 a_3 a_2 a_1 a_0$                                                                                                                                                                                                                                                                                                                  |
|                | This is a 2-cycle instruction. Control passes to the specified address if the accumulator contents are nonzero at the time this instruction is executed.<br>$(PC_{0-7}) \leftarrow addr \qquad if A \neq 0$                                                                                                                                                                |
| Example:       | JACCNO: JNZ OABH ;JUMP TO LOCATION 'AB' HEX<br>;IF ACC VALUE IS NONZERO                                                                                                                                                                                                                                                                                                    |
| JOBF Address   | Jump If Output Buffer Full Flag Is Set                                                                                                                                                                                                                                                                                                                                     |
| Opcode:        | $1 0 0 0 0 1 1 0 \bullet a_7 a_6 a_5 a_4 a_3 a_2 a_1 a_0$                                                                                                                                                                                                                                                                                                                  |
|                | This is a 2-cycle instruction. Control passes to the specified address if the Output Buffer Full (OBF) flag is set $(= 1)$ at the time this instruction is executed.<br>(PC <sub>0-7</sub> ) $\leftarrow$ addr if OBF = 1                                                                                                                                                  |
| Example:       | JOBFHI: JOBF OAAH ;JUMP TO LOCATION 'AA' HEX<br>;IF OBF = 1                                                                                                                                                                                                                                                                                                                |
| JTF address Ju | mp If Timer Flag is Set                                                                                                                                                                                                                                                                                                                                                    |
| Opcode:        | $\begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                                                                                                                                                                                     |
|                | This is a 2-cycle instruction. Control passes to the specified address if the timer flag is set to one, that is, the timer/counter register overflows to zero. The timer flag is cleared upon execution of this instruction. (This overflow initiates an interrupt service sequence if the timer-overflow interrupt is enabled.)<br>$(PC_{0-7}) \leftarrow addr$ if TF = 1 |
| Example:       | JTF1: JTF TIMER ;JUMP TO 'TIMER' ROUTINE<br>;IF TF = $1$                                                                                                                                                                                                                                                                                                                   |



JTO address Jump If TEST 0 Is High

| Opcode:  | 0011 0110                                                                                       | a7 a6 a5 a4 a3 a2 a1 a0                                                                        |
|----------|-------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|
|          | This is a 2-cycle instruction,<br>high (= 1). Pin is sampled of<br>$(PC_{0-7}) \leftarrow addr$ | . Control passes to the specified address if the TEST 0 signal is during SYNC.<br>if $T_0 = 1$ |
| Example: | ЈТОНІ: ЈТО 53                                                                                   | ;JUMP TO LOCATION 53 DEC<br>;IF $T_0 = 1$                                                      |

JT1 address Jump If TEST 1 Is High

| Opcode:  | 0 1 0 1 0 1 1 0 • a <sub>7</sub> a <sub>6</sub> a <sub>5</sub> a <sub>4</sub> a <sub>3</sub> a <sub>2</sub> a <sub>1</sub> a <sub>0</sub>                                           |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | This is a 2-cycle instruction. Control passes to the specified address if the TEST 1 signal is high (= 1). Pin is sampled during SYNC.<br>$(PC_{0-7}) \leftarrow addr$ if $T_1 = 1$ |
| Example: | JT1HI: JT1 COUNT ;JUMP TO 'COUNT' ROUTINE<br>;IF $T_1 = 1$                                                                                                                          |

JZ address Jump If Accumulator Is Zero

| Opcode:  | 1100 0110 •                                                                                     | $a_7 a_6 a_5 a_4 a_3 a_2 a_1 a_0$                                                                   |
|----------|-------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
|          | This is a 2-cycle instruction.<br>tains all zeros at the time this $(PC_{0-7}) \leftarrow addr$ | Control passes to the specified address if the accumulator con-<br>instruction is executed. $ifA=0$ |
| Example: | JACCO: JZ OA3H                                                                                  | ;JUMP TO LOCATION 'A3' HEX<br>;IF ACC VALUE IS ZERO                                                 |

MOV A, # data Move Immediate Data to Accumulator

| Opcode:       | $\begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                 |
|---------------|------------------------------------------------------------------------------------------------------------------------|
|               | This is a 2-cycle instruction. The 8-bit value spedified by 'data' is loaded in the accumulator. (A) $\leftarrow$ data |
| Example:      | MOV A, #OA3H ;MOV 'A3' HEX TO ACC                                                                                      |
| MOV A,PSW Mov | ve PSW Contents to Accumulator                                                                                         |
| Opcode:       |                                                                                                                        |
|               | The contents of the program status word are moved to the accumulator.<br>(A) $\leftarrow$ (PSW)                        |

Example:Jump to 'RB1SET' routine if bank switch, PSW bit 4, is set.<br/>BSCHK: MOV A,PSW<br/>JB4 RB1 SET;MOV PSW CONTENTS TO ACC<br/>;JUMP TO 'RB1SET' IF ACC<br/>;BIT 4 = 1



| Opcode:       | 1 1 1 1 1 1 r <sub>2</sub> r <sub>1</sub> r <sub>0</sub>       |                                                   |
|---------------|----------------------------------------------------------------|---------------------------------------------------|
|               | Eight bits of data are moved from wor<br>(A) $\leftarrow$ (Rr) | king register 'r' into the accumulator. $r = 0-7$ |
| Example:      | MAR: MOV A,R3                                                  | ;MOVE CONTENTS OF REG 3<br>;TO ACC                |
| MOV A,@Rr Mov | ve Data Memory Contents to Accumu                              | lator                                             |

### MOV A,Rr Move Register Contents to Accumulator

| Opcode:  | 1111 000r                                                                                               |                                                                                        |
|----------|---------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
|          | The contents of the data memory loc<br>the accumulator. Register 'r' content<br>(A) $\leftarrow$ ((Rr)) | cation addressed by bits 0-7 of register 'r' are moved to s are unaffected.<br>r = 0-1 |
| Example: | Assume R1 contains 00110110.<br>MADM: MOV A,@R1                                                         | ;MOVE CONTENTS OF DATA MEM<br>;LOCATION 54 TO ACC                                      |



| Opcode:  | 0100                                                  | 0010           |                                                                          |
|----------|-------------------------------------------------------|----------------|--------------------------------------------------------------------------|
|          | The contents<br>event-counter<br>(A) $\leftarrow$ (T) | er is not stop | er/event-counter register are moved to the accumulator. The timer/ ped.  |
| Example: | Jump to "Extion to zero.                              |                | when timer reaches '64', that is, when bit 6 is set—assuming initializa- |
|          | TIMCHK: N                                             | MOV A,T        | ;MOVE TIMER CONTENTS TO<br>:ACC                                          |
|          | J                                                     | B6 EXIT        | ;JUMP TO 'EXIT' IF ACC BIT<br>: $6 = 1$                                  |
|          |                                                       |                | ,0 - 1                                                                   |

| MOV PSW,A | Move Accumulator | Contents to PS\ | N |
|-----------|------------------|-----------------|---|
|-----------|------------------|-----------------|---|

**Opcode:** 1101 0111

The contents of the accumulator are moved into the program status word. All condition bits and the stack pointer are affected by this move. (PSW)  $\leftarrow$  (A)

 

 Example:
 Move up stack pointer by two memory locations, that is, increment the pointer by one. INCPTR: MOV A,PSW
 ;MOVE PSW CONTENTS TO ACC

 INC A
 ;INCREMENT ACC BY ONE

 MOV PSW,A
 ;MOVE ACC CONTENTS TO PSW

| Opcode:        | 1 0 1 0 1 r <sub>2</sub> r <sub>1</sub> r <sub>0</sub>                                                                                                                                                             |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | The contents of the accumulator are moved to register 'r'<br>(Rr) $\leftarrow$ (A) $r = 0-7$                                                                                                                       |
| Example:       | MRA MOV R0,A ;MOVE CONTENTS OF ACC TO ;REG 0                                                                                                                                                                       |
| MOV Rr, # data | Nove Immediate Data to Register                                                                                                                                                                                    |
| Opcode:        | $\begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                             |
|                | This is a 2-cycle instruction. The 8-bit value specified by 'data' is moved to register 'r'.<br>(Rr) $\leftarrow$ data $r = 0-7$                                                                                   |
| Example:       | MIR4: MOV R4, #HEXTEN ;THE VALUE OF THE SYMBOL<br>;'HEXTEN' IS MOVED INTO                                                                                                                                          |
|                | MIR5: MOV R5, #PI*(R*R) ;REG 4<br>;THE VAUE OF THE<br>;EXPRESSION 'PI*(R*R)'                                                                                                                                       |
|                | ;IS MOVED INTO REG 5<br>MIR6: MOV R6, #OADH ;'AD' HEX IS MOVED INTO<br>REG 6                                                                                                                                       |
| MOV @Rr,A Mov  | ve Accumulator Contents to Data Memory                                                                                                                                                                             |
| Opcode:        | 1010 000r                                                                                                                                                                                                          |
|                | The contents of the accumulator are moved to the data memory location whose address is specified by bits 0-7 of register 'r'. Register 'r' contents are unaffected.<br>((Rr)) $\leftarrow$ (A) $r = 0-1$           |
| Example:       | Assume R0 contains 11000111.<br>MDMA: MOV @R,A ;MOVE CONTENTS OF ACC TO<br>;LOCATION 7 (REG)                                                                                                                       |
| MOV @Rr,#data  | Move Immediate Data to Data Memory                                                                                                                                                                                 |
| Opcode:        | $\begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                             |
|                | This is a 2-cycle instruction. The 8-bit value specified by 'data' is moved to the standard data memory location addressed by register 'r', bit 0-7.                                                               |
| Example:       | Move the hexadecimal value AC3F to locations 62–63.MIDM: MOV R0, #62;MOVE '62' DEC TO ADDR REG0MOV @RO, #OACH;MOVE 'AC' HEX TO LOCATION 62INC R0;INCREMENT REG 0 TO '63'MOV @R0, #3FH;MOVE '3F' HEX TO LOCATION 63 |

#### MOV Rr,A Move Accumulator Contents to Register



| Opcode:  | 1001 0000                                                                       |                                                                     |
|----------|---------------------------------------------------------------------------------|---------------------------------------------------------------------|
|          | The contents of the accumula $(STS_{4-7}) \leftarrow (A_{4-7})$                 | tor are moved into the status register. Only bits 4–7 are affected. |
| Example: | Set ST <sub>4</sub> –ST <sub>7</sub> to "1".<br>MSTS: MOV A, #0F0H<br>MOV STS,A | ;SET ACC<br>;MOVE TO STS                                            |

| MOV STS,A | Move Accumulator ( | Contents to | STS Register |
|-----------|--------------------|-------------|--------------|
|           |                    |             |              |

| MOV T,A | Move Accumulator | Contents to | Timer/Counter |
|---------|------------------|-------------|---------------|
|---------|------------------|-------------|---------------|

| Opcode:  | 0 1 1 0 0 0 1 0                                                 |                                                                       |
|----------|-----------------------------------------------------------------|-----------------------------------------------------------------------|
|          | The contents of the accumulator are motion $(T) \leftarrow (A)$ | ved to the timer/event-counter register.                              |
| Example: | Initialize and start event counter.                             |                                                                       |
|          | INITEC: CLR A<br>MOV T,A<br>STRT CNT                            | ;CLEAR ACC TO ZEROS<br>;MOVE ZEROS TO EVENT COUNTER<br>;START COUNTER |



| Opcode:        | 0 0                        | 0 0            | 1 1 p           | 1 P0                                                                                                   |
|----------------|----------------------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------|
|                | Accur<br>(A <sub>0-3</sub> |                | r bits 4–<br>Pp | ruction. Data on 8243 port 'p' is moved (read) to accumulator bits 0–3. 7 are zeroed. $p = 4-7$        |
| Note:          |                            |                |                 | de are used to represent PORTS 4–7. If you are coding in binary rather age, the mapping is as follows: |
|                | В                          | its            | Port            |                                                                                                        |
|                | <b>P</b> 1                 | p <sub>0</sub> |                 |                                                                                                        |
|                | 0                          | 0              | 4               |                                                                                                        |
|                | 0                          | 1              | 5               |                                                                                                        |
|                | 1                          | 0              | 6               |                                                                                                        |
|                | 1                          | 1              | 7               |                                                                                                        |
| Example:       | INPP                       | T5: M          | OVD A,          | P5 ;MOVE PORT 5 DATA TO ACC<br>;BITS 0-3, ZERO ACC BITS 4-7                                            |
| MOVD Pp,A Move | e Accu                     | mulat          | or Data         | to Port 4, 5, 6 and 7                                                                                  |
| Opcode:        | 0 0                        | 11             | 1 1 p           | 1 P0                                                                                                   |
|                | This is                    | s a 2-cy       | vcle instr      | ruction. Data in accumulator bits $0-3$ is moved (written) to 8243 port 'p'.                           |

Accumulator bits 4–7 are unaffected. (See NOTE above regarding port mapping.)

| Example: | Move data in accumulator to ports 4 and 5. |                                |  |  |
|----------|--------------------------------------------|--------------------------------|--|--|
|          | OUTP45: MOVD P4,A                          | ;MOVE ACC BITS 0-3 TO PORT 4   |  |  |
|          | SWAP A                                     | ;EXCHANGE ACC BITS 0-3 AND 4-7 |  |  |
|          | MOVD P5,A                                  | ;MOVE ACC BITS 0-3 TO PORT 5   |  |  |

44

| MOVP A,@A | Move Current Page Data to Accumulator |  |
|-----------|---------------------------------------|--|
|           |                                       |  |

| Opcode:  | 1010 0011                                                                                                                                                                                                                                                                                                                                 |                                                                                                |  |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|--|
|          | This is a 2-cycle instruction. The contents of the program memory location addressed by the accumulator are moved to the accumulator. Only bits $0-7$ of the program counter are affected, limiting the program memory reference to the current page. The program counter is restored following this operation.<br>(A) $\leftarrow$ ((A)) |                                                                                                |  |
| Note:    | This a 1-byte, 2-cycle instruction. If it appears in location 255 of a program memory page, @A addresses a location in the following page.                                                                                                                                                                                                |                                                                                                |  |
| Example: | MOV128: MOV A, #128<br>MOVP A,@A                                                                                                                                                                                                                                                                                                          | ;MOVE '128' DEC TO ACC<br>;CONTENTS OF 129TH LOCATION<br>;IN CURRENT PAGE ARE MOVED TO<br>;ACC |  |

MOVP3 A,@A Move Page 3 Data to Accumulator

| Opcode:  | 1 1 1 0 0 0 1 1                                                                              |                                                                                                                                                                                                                                                                                  |
|----------|----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                                                                                              | ents of the program memory location within page 3, d to the accumulator. The program counter is restored                                                                                                                                                                         |
| Example: | 1 1                                                                                          | nal code in table contained at the beginning of page 3.<br>ted by a 7-bit code; the eighth bit is always reset.<br>;MOVE 'B8' HEX TO ACC (10111000)<br>;LOGICAL AND ACC TO MASK BIT<br>;7 (00111000)<br>;MOVE CONTENTS OF LOCATION<br>;'38' HEX IN PAGE 3 TO ACC<br>;(ASCII '8') |
|          | Access contents of location in page 3 la<br>in page 3.<br>TABSCH: MOV A, #TAB1<br>MOVP3 A,@A | (ABCH '6')<br>belled TAB1. Assume current program location is not<br>;ISOLATE BITS 0–7<br>;OF LABEL<br>;ADDRESS VALUE<br>;MOVE CONTENT OF PAGE 3<br>;LOCATION LABELED 'TAB1'<br>;TO ACC                                                                                          |

#### NOP The NOP Instruction

|--|

No operation is performed. Execution continues with the following instruction.

| ORL A,Rr | Logical OR Accumulator With Register Mask |
|----------|-------------------------------------------|
|          |                                           |

| Opcode:  | 0 1 0 0 1 r <sub>2</sub> r <sub>1</sub> r <sub>0</sub>                 |                                                                 |
|----------|------------------------------------------------------------------------|-----------------------------------------------------------------|
|          | Data in the accumulator is logically C<br>(A) $\leftarrow$ (A) OR (Rr) | DRed with the mask contained in working register 'r'. $r = 0-7$ |
| Example: | ORREG: ORL A,R4                                                        | ;'OR' ACC CONTENTS WITH<br>;MASK IN REG 4                       |



| ORL A,@Rr Logi   | ical OR Accumulator With Memory Mask                                                                                                                                                    |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Opcode:          | 0 1 0 0 0 0 0 r                                                                                                                                                                         |
|                  | Data in the accumulator is logically ORed with the mask contained in the data memory location referenced by register 'r', bits 0-7.<br>(A) $\leftarrow$ (A) OR ((Rr)) $r = 0-1$         |
| Example:         | ORDM: MOVE R0, #3FH<br>ORL A, @R0<br>;'OR' ACC CONTENTS WITH MASK<br>;IN LOCATION 63                                                                                                    |
| ORL A, # Data Lo | ogical OR Accumulator With Immediate Mask                                                                                                                                               |
| Opcode:          | $\begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                  |
|                  | This is a 2-cycle instruction. Data in the accumulator is logically ORed with an immediately-specified mask.<br>(A) $\leftarrow$ (A) OR data                                            |
| Example:         | ORID: ORL A, # 'X' ;'OR' ACC CONTENTS WITH MASK<br>;01011000 (ASCII VALUE OF 'X')                                                                                                       |
| ORL Pp, # data L | ogical OR Port 1–2 With Immediate Mask                                                                                                                                                  |
| Opcode:          | $\begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                  |
|                  | This is a 2-cycle instruction. Data on port 'p' is logically ORed with an immediately-specified mask.                                                                                   |
|                  | (Pp) $\leftarrow$ (Pp) OR data $p = 1-2$ (see OUTL instruction)                                                                                                                         |
| Example:         | ORP1: ORL P1,#OFH ;'OR' PORT 1 CONTENTS WITH<br>;MASK 'FF' HEX (SET PORT 1<br>'TO ALL ONES)                                                                                             |
| ORLD Pp,A Logi   | ical OR Port 4–7 With Accumulator Mask                                                                                                                                                  |
| Opcode:          | 1000 11p1p0                                                                                                                                                                             |
|                  | This is a 2-cycle instruction. Data on 8243 port 'p' is logically ORed with the digit mask                                                                                              |
|                  | contained in accumulator bits 0–3,<br>(Pp) (Pp) OR ( $A_{0-3}$ ) p = 4–7 (See MOVD instruction)                                                                                         |
| Example:         | ORP7; ORLD P7,A;'OR' PORT 7 CONTENTS<br>;WITH ACC BITS 0–3                                                                                                                              |
| OUT DBB,A Out    | put Accumulator Contents to Data Bus Buffer                                                                                                                                             |
| Opcode:          | 0000 0010                                                                                                                                                                               |
|                  | Contents of the accumulator are transferred to the Data Bus Buffer Output register and the Output Buffer Full (OBF) flag is set to one.<br>(DBB) $\leftarrow$ (A)<br>OBF $\leftarrow$ 1 |

**Example:** OUTDBB: OUT DBB,A

;OUTPUT THE CONTENTS OF ;THE ACC TO DBBOUT

46

| Opcode:     | 0 0        | 11             | 10p <sub>1</sub> | P <sub>0</sub>                                                                                              |
|-------------|------------|----------------|------------------|-------------------------------------------------------------------------------------------------------------|
|             |            | d latch        | ed.              | uction. Data residing in the accumulator is transferred (written) to port $\mathbf{P}=1{-}2$                |
| Note:       |            |                |                  | e are used to represent PORT 1 and PORT 2. If you are coding in binary language, the mapping is as follows: |
|             | Bi         | its            | Port             |                                                                                                             |
|             | <b>P</b> 1 | P <sub>0</sub> |                  |                                                                                                             |
|             | 0          | 0              | x                |                                                                                                             |
|             | 0          | 1              | 1                |                                                                                                             |
|             | 1          | 0              | 2                |                                                                                                             |
|             | 1          | 1              | X                |                                                                                                             |
| Example:    | OUTI       | LP; MO         | OV A,R7          | ;MOVE REG 7 CONTENTS TO ACC                                                                                 |
|             |            |                | JTL P2,A         |                                                                                                             |
|             |            |                | OV A,R6          |                                                                                                             |
|             |            | ot             | JTL P1,A         | ;OUTPUT ACC CONTENTS TO PORT 1                                                                              |
| Return Witl | hout PS    | W Re           | store            |                                                                                                             |

#### OUTL Pp,A Output Accumulator Data to Port 1 and 2

RET

Opcode:

1000 0011

This is a 2-cycle instruction. The stack pointer (PSW bits 0-2 is decremented. The program counter is then restored from the stack. PSW bits 4-7 are not restored.  $\begin{array}{rcl} (\text{SP}) & \longleftarrow & (\text{SP}) - 1 \\ (\text{PC}) & \longleftarrow & ((\text{SP})) \end{array}$ 

#### **RETR Return With PSW Restore**

1001 0011 Opcode:

> This is a 2-cycle instruction. The stack pointer is decremented. The program counter and bits 4-7 of the PSW are then restored from the stack. Note that RETR should be used to return from an interrupt, but should not be used within the interrupt service routine as it signals the end of an interrupt routine. (SP)  $\leftarrow$  (SP) -1(PC)  $\leftarrow$  ((SP)) (PSW<sub>4-7</sub>)  $\leftarrow$  ((SP))

#### RLA Rotate Left Without Carry

| Opcode:  | 1 1 1 0 0 1 1 1                                                                                                                                                           |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | The contents of the accumulator are rotated left one bit. Bit 7 is rotated into the bit 0 position.<br>$(A_{n+1}) \leftarrow (A_n)$ $n = 0-6$<br>$(A_0) \leftarrow (A_7)$ |
| Example: | Assume accumulator contains 10110001.<br>RLNC: RL A ;NEW ACC CONTENTS ARE 01100011                                                                                        |



#### RLC A Rotate Left Through Carry

| Opcode:  | 1 1 1 1 0 1 1 1                                                                 |                                                                                                                           |
|----------|---------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|
|          | bit is rotated into the bit 0 posit                                             | are rotated left one bit. Bit 7 replaces the carry bit; the carry ion.                                                    |
|          | $(A_{n+1}) \leftarrow (A_n)$<br>$(A_0) \leftarrow (C)$<br>$(C) \leftarrow (A7)$ | n = 0-6                                                                                                                   |
| Example: | Assume accumulator contains a<br>RLTC: CLR C<br>RLC A                           | 'signed' number; isolate sign without changing value.<br>;CLEAR CARRY TO ZERO<br>;ROTATE ACC LEFT, SIGN                   |
|          | RR A                                                                            | ;BIT (7) IS PLACED IN CARRY<br>;ROTATE ACC RIGHT—VALUE<br>;(BITS 0–6) IS RESTORED,<br>;CARRY UNCHANGED, BIT 7<br>;IS ZERO |

#### RR A Rotate Right Without Carry

| Opcode: | 0111 0111                                                                           |                                                                         |
|---------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
|         | The contents of the accumulator position.<br>(A) $\leftarrow$ (A <sub>n + 1</sub> ) | r are rotated right one bit. Bit 0 is rotated into the bit 7<br>n = 0-6 |
|         | $(A_7) \leftarrow (A_0)$                                                            |                                                                         |
| Example | Assume accumulator contains 10<br>RRNC: RRA                                         | 110001.<br>NEW ACC CONTENTS ARE 11011000                                |

#### RRC A Rotate Right Through Carry

| Opcode: | 0110 0111                               |                                                           |
|---------|-----------------------------------------|-----------------------------------------------------------|
|         | rotated into the bit 7 position.        | d one bit. Bit 0 replaces the carry bit; the carry bit is |
|         | $(A_n) \leftarrow (A_n + 1)$            | n = 0-6                                                   |
|         | $(A_7) \leftarrow (C)$                  |                                                           |
|         | (C) $\leftarrow$ (A <sub>0</sub> )      |                                                           |
| Example | Assume carry is not set and accumulator | contains 10110001.                                        |
|         | RRTC: RRCA ;                            | CARRY IS SET AND ACC                                      |
|         | ;                                       | CONTAINS 01011000                                         |

| SEL RB0 S | Select F | Register Bank 0                                                                                                                                                                                      |                                                                                                                                                                                                                                                     |  |
|-----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Орс       | ode:     | $1 1 0 0$ $0 1 0 1$ PSW BIT 4 is set to zero. References to working registers 0–7 address data memory locations0-7. This is the recommended setting for normal program execution.(BS) $\leftarrow 0$ |                                                                                                                                                                                                                                                     |  |
| SEL RB1 S | Select F | Register Bank 1                                                                                                                                                                                      |                                                                                                                                                                                                                                                     |  |
| Орс       | ode:     | 24–31. This is the recommended left intact. The setting of PSW                                                                                                                                       | ences to working registers $0-7$ address data memory locations<br>ed setting for interrupt service routines, since locations $0-7$ are<br>V bit 4 in effect at the time of an interrupt is restored by the<br>terrupt service routine is completed. |  |
| Example:  |          | Assume an IBF interrupt has o<br>PSW bit 4 was zero before the<br>LOC3: JMP INIT                                                                                                                     | ccurred, control has passed to program memory location 3, and<br>interrupt.<br>;JUMP TO ROUTINE 'INIT'                                                                                                                                              |  |
|           |          | INIT: MOV R7,A<br>SEL RB1<br>MOV R7,#OFAH                                                                                                                                                            | ;MOV ACC CONTENTS TO<br>;LOCATION 7<br>;SELECT REG BANK 1<br>;MOVE 'FA' HEX TO LOCATION 31                                                                                                                                                          |  |
|           |          | SEL RB0<br>MOV A,R7<br>RETR                                                                                                                                                                          | ;SELECT REG BANK 0<br>;RESTORE ACC FROM LOCATION 7<br>;RETURN——RESTORE PC AND PSW                                                                                                                                                                   |  |

#### 49



| Opcode:       0 1 1 0 0 1 0 1         This instruction is used to stop both time accumulation and event counting.         Example:       Disable interrupt, but jump to interrupt routine after eight overflows and stop timer. Cound overflows in register 7.         START: DIS TCNT1       :DISABLE TIMER INTERRUPT         CLR A       :CLEAR ACC TO ZERO         MOV ZA       :MOV ZERO TO TIMER         MOV R7.A       :MOV ZERO TO REG 7         STR T:       :START: DISTONT         JUMP TO ROUTINE 'COUNT       :JUMP TO ROUTINE 'COUNT'         MAIN:       :JTF = 1 AND CLEAR TIMER FLAG         MOV R.7       :MOVE REG 7 CONTENTS TO ACC         JUMP MAIN       :CLOSE LOOP         COUNT: INC R7       :INCREMENT REG 7         MOV A.R7       :JUMP TO ROUTINE 'INT IF ACC         JBS INT       :JUMP TO ROUTINE 'INT IF ACC         JMP MAIN       :CHERWISE RETURN TO ROUTINE 'INT IF ACC          :INT: STOP TCNT       :STOP TIMER         JMP 7H       :JUMP TO LOCATION 7 (TIMER         JMP 7H       :JUMP TO LOCATION 7 (TIMER         MOV A.* OFFH       :MAIN          :         START: Event Counter       Opcode:         Opcode:       0 1 0 1 0 1         START: EXT TIMER       : <th></th> <th></th>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Example:Disable interrupt, but jump to interrupt routine after eight overflows and stop timer. Courdows in register 7.<br>START: DIS TCNTI<br>CLR A<br>MOV 7.A<br>MOV ZERO TO TIMER<br>MOV 7.A<br>STRT T<br>START TIMER<br>MAIN: JTF COUNT<br>JMP MAIN<br>CLOSE LOOP<br>COUNT: INC R7<br>JMP MAIN<br>CLOSE LOOP<br>COUNT: INC R7<br>JMP MAIN<br>CLOSE LOOP<br>COUNT: INC R7<br>JMP MAIN<br>CLOSE LOOP<br>COUNT: STATT T<br>JMP MAIN<br>CLOSE LOOP<br>COUNT: STOP TCNT<br>JMP MAIN<br>STRT T<br>STATT Start Event CounterSTOP TIMER<br>STOP TCNT<br>STOP TCNT<br>JMP MAIN<br>STOP TCNT<br>STOP TCNT<br>STATT EN TCNT<br>STARTC EN TCNT<br>STARTT EN TCNTI<br>STARTT EN TCNTI <b< th=""><th>0110 0101</th><th></th></b<> | 0110 0101                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| overflows in register 7.ISTART: DIS TCNTI; DISABLE TIMER INTERRUPTCLR A; CLEAR ACC TO ZEROMOV T,A; MOV ZERO TO TIMERMOV R7,A; MOV ZERO TO TIMERMON R7,A; MOV ZERO TO REG 7STRT T; START TIMERMAIN: JTF COUNT; JUMP TO ROUTINE 'COUNT'; IF TF = 1 AND CLEAR TIMER FLAGJMP MAIN; CLOSE LOOPCOUNT: INC R7; INCREMENT REG 7MOV A,R7; MOVE REG 7 CONTENTS TO ACCJB3 INT; JUMP TO ROUTINE 'INT' IF ACC; BIT 3 IS SET (REG 7 = 8)JMP MAIN; OTHERWISE RETURN TO ROUTINE; MAIN <td< th=""><th>This instruction is used to stop both</th><th>h time accumulation and event counting.</th></td<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | This instruction is used to stop both                                                                                                                                                           | h time accumulation and event counting.                                                                                                                                                                                                                                                                                                                                                                                              |
| START: DIS TCNTI DISABLE TIMER INTERRUPT<br>CLR A ;CLEAR ACC TO ZERO<br>MOV T,A ;MOV ZERO TO TIMER<br>MOV R7,A ;MOVE ZERO TO REG 7<br>STRT T ;START TIMER<br>MAIN: JTF COUNT ;JUMP TO ROUTINE 'COUNT'<br>IF TF = 1 AND CLEAR TIMER FLAG<br>JMP MAIN ;CLOSE LOOP<br>COUNT: INC R7 ;INCREMENT REG 7<br>MOV A,R7 ;MOVE REG 7 CONTENTS TO ACC<br>JB3 INT ;JUMP TO ROUTINE TNT IF ACC<br>JB3 INT ;JUMP TO ROUTINE TNT IF ACC<br>JB3 INT ;JUMP TO ROUTINE TNT IF ACC<br>JMP MAIN ;OTHERWISE RETURN TO ROUTINE<br>;MAIN<br><br>INT: STOP TCNT ;STOP TIMER<br>JMP 7H ;JUMP TO LOCATION 7 (TIMER<br>;INTERRUPT ROUTINE)<br>ST CNT Start Event Counter<br>The TEST 1 (T,1) pin is enabled as the event-counter input and the counter is started. The<br>event-counter register is incremented with each high to low transition on the T <sub>1</sub> pin.<br>Example: Initialize and start event counter. Assume overflow is desired with first T <sub>1</sub> input.<br>STARTC: EN TCNT1 ;ENABLE COUNTER INTERRUPT<br>MOV A, #OFFH ;MOVE TF' HEX (ONES) TO<br>ACC<br>MOV T,A ;MOVE ONES TO COUNTER<br>STRT CNT ;INPUT AND START<br>NT T Start Timer<br>Opcode: 0 1 0 1 0 1 0 1<br>Timer accumulation is initiated in the timer register. The register is incremented every 3<br>instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register<br>not.<br>Example: Initialize and start timer.<br>STARTT: EN TCNT1 ;ENABLE TIMER INTERRUPT<br>CLR A ;CLEAR ACC TO ZEROS<br>MOV T,A ;MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                 | rrupt routine after eight overflows and stop timer. Coun                                                                                                                                                                                                                                                                                                                                                                             |
| $MOV T.A \qquad :MOV ZERO TO TIMER MOV R7.A :MOVE ZERO TO REG 7 STRT T :START TIMER MAIN: JTF COUNT :JUMP TO ROUTINE COUNT :IFT F = 1 AND CLEAR TIMER FLAG JMP MAIN :CLOSE LOOP COUNT: INC R7 :INCREMENT REG 7 MOV A, R7 :MOVE REG 7 CONTENTS TO ACC JB3 INT :JUMP TO ROUTINE 'INT IF ACC :BIT 3 IS SET (REG 7 = 8) JMP MAIN :OTHERWISE RETURN TO ROUTINE :MAIN : . INT: STOP TCNT :STOP TIMER JMP 7H :JUMP TO LOCATION 7 (TIMER ;INTERRUPT ROUTINE) The TEST 1 (T1) pin is enabled as the event-counter input and the counter is started. The event-counter register is incremented with each high to low transition on the T1 pin. Example: Initialize and start event counter. Assume overflow is desired with first T1 input. STARTC: EN TCNT : ENABLE COUNTER INTERRUPT MOV A, #OFFH :MOV FTF HEX (ORES) TO : ACC MOV T,A :MOVE ONES TO COUNTER STRT CNT Start Timer Opcode: 0 1 0 1 0 1 0 1 Timer accumulation is initiated in the timer register. The register is incremented every 3 instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register tot. Example: Initialize and start timer. STARTT: EN TCNTI :ENABLE TIMER INTERRUPT MOV A, # 0FFH :MOVE ONES TO COUNTER STRT CNT :INPUT AND START RT T Start Timer Example: Initialize and start timer. STARTT: EN TCNTI :ENABLE TIMER INTERRUPT CLEAR ACC TO ZEROS MOV T,A :MOVE ZEROS TO TIMER$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | START: DIS TCNTI                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| MOV R7.A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| STR TSTAR T TIMERMAIN: JTF COUNT:JUMP TO ROUTINE 'COUNT':IF TF = 1 AND CLEAR TIMER FLAGJMP MAIN;CLOSE LOOPCOUNT: INC R7:MOVE REG 7MOV A,R7:MOVE REG 7 CONTENTS TO ACCJB3 INT:JUMP TO ROUTINE 'TM' IF ACC'BIT 3 IS SET (REG 7 = 8)JMP MAIN;OTHERWISE RETURN TO ROUTINE::MIN::INT: STOP TCNT::STOP TIMERJMP 7H:JUMP TO LOCATION 7 (TIMER::INTERRUPT ROUTINE)RT CNT Start Event CounterOpcode: $0 1 0 0 0 1 0 1$ The TEST 1 (T <sub>1</sub> ) pin is enabled as the event-counter input and the counter is started. TI event-counter register is incremented with each high to low transition on the T <sub>1</sub> pin.Example:Initialize and start event counter. Assume overflow is desired with first T <sub>1</sub> input.STARTC: EN TCNTI:ENABLE COUNTER INTERRUPT:ACCMOV A, #OFFH:MOVE ONES TO COUNTER:ACC:MOV T,A:MOVE TF' HEX (ONES) TO:ACCMOV T,A:MOVE ONES TO COUNTER:STRT CNT:INPUT AND STARTRT T Start TimerOpcode: $0 1 0 1 0 1 0$ Timer accumulation is initiated in the timer register. The register is incremented every 3 instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register not.Example:Initialize and start timer.STARTT: EN TCNTI:ENABLE TIMER INTERRUPT:CLR A:CLR A ACC TO ZEROS:MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| MAIN:JTF COUNTJUMP TO ROUTINE 'COUNT'<br>IF TF = 1 AND CLEAR TIMER FLAG<br>JMP MAINJMP MAIN:CLOSE LOOP<br>COUNT: INC R7;INCREMENT REG 7<br>MOV A,R7MOV A,R7:MOVE REG 7 CONTENTS TO ACC<br>BIT 31S SET (REG 7 = 8)JMP MAIN:OTHERWISE RETURN TO ROUTINE<br>:MAIN:::::::::::::::::::::::::::::::::::::::::::::::::::::                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| IF TF = 1 AND CLEAR TIMER FLAG COUNT: INC R7 MOV A,R7 JUMP MAIN COUNT: INC R7 MOV A,R7 JUMP TO ROUTINE TO ACC JB3 INT JUMP TO ROUTINE TO ROUTINE BIT 3 IS SET (REG 7 = 8) JMP MAIN COUNT: STOP TCNT JUMP TO LOCATION 7 (TIMER JMP 7H JUMP TO LOCATION 7 (TIMER INT: STOP TCNT STOP THER JUMP TO LOCATION 7 (TIMER INTERRUPT ROUTINE) ST CNT Start Event Counter Opcode: $0 1 0 0 0 1 0 1The TEST 1 (T1) pin is enabled as the event-counter input and the counter is started. Thevent-counter register is incremented with each high to low transition on the T1 pin.Example:Initialize and start event counter. Assume overflow is desired with first T1 input.STARTC: EN TCNTSTARTC: EN TCNTMOV A, #OFFHMOVE ONES TO COUNTERSTRT CNTSTRT C$                                                                                                                                                                                                        |                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| COUNT: INC R7INCREMENT REG 7MOV A,R7MOVE REG 7 CONTENTS TO ACCJB3 INTJUMP TO ROUTINE 'INT' IF ACCBIT 3 IS SET (REG 7 = 8)JMP MAIN:OTHERWISE RETURN TO ROUTINEINT: STOP TCNT;STOP TIMERJMP 7H;JUMP TO LOCATION 7 (TIMERJMP 7H:INTERRUPT ROUTINE)NT CNT Start Event CounterOpcode: $0 1 0 0$ $0 1 0 1$ The TEST 1 (T1) pin is enabled as the event-counter input and the counter is started. The event-counter register is incremented with each high to low transition on the T1 pin.Example:Initialize and start event counter. Assume overflow is desired with first T1 input.STARTC: EN TCNTI;ENABLE COUNTER INTERRUPT<br>MOV A, #OFFHMOVE 'FF' HEX (ONES) TO<br>:ACCMOV T,A;MOVE ONES TO COUNTER<br>STRT CNTTIMER counter to the timer register. The register is incremented every 3instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register<br>not.Example:Initialize and start timer.<br>STARTT: EN TCNTI;ENABLE TIMER INTERRUPT<br>cLR A<br>CLR A<br>CLEAR ACC TO ZEROS<br>MOV T,ASTARTT: EN TCNTI<br>CLR A<br>CUC AR ACC TO ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | JMP MAIN                                                                                                                                                                                        | CLOSE LOOP                                                                                                                                                                                                                                                                                                                                                                                                                           |
| JB3 INT;JUMP TO ROUTINE 'INT' IF ACC<br>(BIT 3 IS SET (REG 7 = 8)JMP MAIN;OTHERWISE RETURN TO ROUTINE<br>(MAIN <th></th> <th></th>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| BIT 3 IS SET (REG 7 = 8)<br>OTHERWISE RETURN TO ROUTINE<br>MAIN<br>The TEST 1 (T1) pin is enabled as the event-counter input and the counter is started. The<br>event-counter register is incremented with each high to low transition on the T1 pin.<br>Example: Initialize and start event counter. Assume overflow is desired with first T1 input.<br>STARTC: EN TCNTI :ENABLE COUNTER INTERRUPT<br>MOV A, #OFFH :MOVE 'FF' HEX (ONES) TO<br>ACCC<br>MOV T,A :MOVE ONES TO COUNTER<br>STRT CNT Start Timer<br>Timer accumulation is initiated in the timer register. The register is incremented every 3<br>instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register<br>initialize and start timer.<br>STARTT: EN TCNTI :ENABLE TIMER INTERRUPT<br>CLR A :CLEAR ACC TO ZEROS<br>MOV T,A :MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                 | ;MOVE REG 7 CONTENTS TO ACC                                                                                                                                                                                                                                                                                                                                                                                                          |
| JMP MAIN       :OTHERWISE RETURN TO ROUTINE         :MAIN       :MAIN         INT: STOP TCNT       :STOP TIMER         JMP 7H       :JUMP TO LOCATION 7 (TIMER         :INTERRUPT ROUTINE)       :INTERRUPT ROUTINE)         RT CNT Start Event Counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | JB3 INT                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| MAIN<br>INT: STOP TCNT STOP TIMER<br>JMP 7H JUMP TO LOCATION 7 (TIMER<br>;INTERRUPT ROUTINE)<br>TCNT Start Event Counter<br>Opcode: 0 1 0 0 0 1 0 1<br>The TEST 1 (T <sub>1</sub> ) pin is enabled as the event-counter input and the counter is started. The<br>event-counter register is incremented with each high to low transition on the T <sub>1</sub> pin.<br>Example: Initialize and start event counter. Assume overflow is desired with first T <sub>1</sub> input.<br>STARTC: EN TCNTI ::ENABLE COUNTER INTERRUPT<br>MOV A, # OFFH ;MOVE 'FF' HEX (ONES) TO<br>;ACC<br>MOV T,A ;MOVE ONES TO COUNTER<br>STRT CNT ;INPUT AND START<br>TT Start Timer<br>TT Start Timer<br>Copcode: 0 1 0 1 0 1 0 1<br>Timer accumulation is initiated in the timer register. The register is incremented every 3<br>instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register<br>not.<br>Example: Initialize and start timer.<br>STARTT: EN TCNTI ::ENABLE TIMER INTERRUPT<br>CLR A ::CLEAR ACC TO ZEROS<br>MOV T,A ::MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | IMP MAIN                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| INT: STOP TCNT       ;STOP TIMER         JMP 7H       ;JUMP TO LOCATION 7 (TIMER         ;INTERRUPT ROUTINE)       :INTERRUPT ROUTINE)         TCNT Start Event Counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | JIVII IVIAIIN                                                                                                                                                                                   | ,                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| JMP 7H       ;JUMP TO LOCATION 7 (TIMER<br>;INTERRUPT ROUTINE)         T CNT Start Event Counter       Interest Counter         Opcode:       0 1 0 0 0 1 0 1         The TEST 1 (T <sub>1</sub> ) pin is enabled as the event-counter input and the counter is started. The event-counter register is incremented with each high to low transition on the T <sub>1</sub> pin.         Example:       Initialize and start event counter. Assume overflow is desired with first T <sub>1</sub> input.         STARTC: EN TCNTI       ;ENABLE COUNTER INTERRUPT<br>MOV A, #OFFH         MOV T,A       ;MOVE ONES TO COUNTER<br>;INPUT AND START         TT Start Timer       Interaccumulation is initiated in the timer register. The register is incremented every 3 instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register not.         Example:       Initialize and start timer.         STARTT: EN TCNTI       ;ENABLE TIMER INTERRUPT register is incremented every 3 instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register not.         Example:       Initialize and start timer.         STARTT: EN TCNTI       ;ENABLE TIMER INTERRUPT CLR A CC TO ZEROS MOV T, A ;MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                 | <u><u>j</u></u>                                                                                                                                                                                                                                                                                                                                                                                                                      |
| JMP 7H       ;JUMP TO LOCATION 7 (TIMER<br>;INTERRUPT ROUTINE)         T CNT Start Event Counter       INTERSUPT ROUTINE)         T CNT Start Event Counter       0 1 0 0 0 1 0 1         The TEST 1 (T <sub>1</sub> ) pin is enabled as the event-counter input and the counter is started. Th event-counter register is incremented with each high to low transition on the T <sub>1</sub> pin.         Example:       Initialize and start event counter. Assume overflow is desired with first T <sub>1</sub> input.         STARTC: EN TCNTI       ;ENABLE COUNTER INTERRUPT<br>MOV A, #OFFH         MOV T,A       ;MOVE ONES TO COUNTER<br>;INPUT AND START         TT Start Timer       Inter accumulation is initiated in the timer register. The register is incremented every 3 instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register not.         Example:       Initialize and start timer.         STARTT: EN TCNTI       ;ENABLE TIMER INTERRUPT register is incremented every 3 instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register not.         Example:       Initialize and start timer.         STARTT: EN TCNTI       ;ENABLE TIMER INTERRUPT CLR A CC TO ZEROS MOV T, A ;MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| ;INTERRUPT ROUTINE)         Start Event Counter         Opcode:       0 1 0 0 0 1 0 1         The TEST 1 (T <sub>1</sub> ) pin is enabled as the event-counter input and the counter is started. The event-counter register is incremented with each high to low transition on the T <sub>1</sub> pin.         Example:         Initialize and start event counter. Assume overflow is desired with first T <sub>1</sub> input.         STARTC: EN TCNTI : ENABLE COUNTER INTERRUPT         MOV A, #OFFH : ;MOVE 'FF' HEX (ONES) TO ;ACC         MOV T,A ;MOVE ONES TO COUNTER         STRT CNT ; INPUT AND START         STT Start Timer         Opcode:         0 1 0 1       0 1 0 1         Timer accumulation is initiated in the timer register. The register is incremented every 3 instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register not.         Example:         Initialize and start timer.         STARTT: EN TCNTI ; ENABLE TIMER INTERRUPT ; CLR A ; CLEAR ACC TO ZEROS ; MOV T, A ; MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| T CNT Start Event Counter         Opcode: $0 1 0 0$ $0 1 0 1$ The TEST 1 (T <sub>1</sub> ) pin is enabled as the event-counter input and the counter is started. The event-counter register is incremented with each high to low transition on the T <sub>1</sub> pin.         Example:       Initialize and start event counter. Assume overflow is desired with first T <sub>1</sub> input. STARTC: EN TCNTI ; ENABLE COUNTER INTERRUPT MOV A, #OFFH ;MOVE 'FF' HEX (ONES) TO ;ACC MOV T,A ;MOVE ONES TO COUNTER STRT CNT ; INPUT AND START         TT Start Timer       Opcode: $0 1 0 1$ $0 1 0 1$ Timer accumulation is initiated in the timer register. The register is incremented every 3 instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register not.         Example:       Initialize and start timer. STARTT: EN TCNTI ; ENABLE TIMER INTERRUPT CLR A ; CLEAR ACC TO ZEROS MOV T,A ; MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | JMP 7H                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Opcode:       0 1 0 0       0 1 0 1         The TEST 1 (T <sub>1</sub> ) pin is enabled as the event-counter input and the counter is started. The event-counter register is incremented with each high to low transition on the T <sub>1</sub> pin.         Example:       Initialize and start event counter. Assume overflow is desired with first T <sub>1</sub> input. STARTC: EN TCNTI ;ENABLE COUNTER INTERRUPT MOV A, #OFFH ;MOVE FF 'HEX (ONES) TO ;ACC MOV T,A ;MOVE ONES TO COUNTER STRT CNT ;INPUT AND START         TT Start Timer       Opcode:       0 1 0 1       0 1 0 1         Timer accumulation is initiated in the timer register. The register is incremented every 3 instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register not.         Example:       Initialize and start timer. STARTT: EN TCNTI ;ENABLE TIMER INTERRUPT CLR A ;CLEAR ACC TO ZEROS MOV T,A ;MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                 | ;INTERRUPT ROUTINE)                                                                                                                                                                                                                                                                                                                                                                                                                  |
| The TEST 1 (T <sub>1</sub> ) pin is enabled as the event-counter input and the counter is started. The event-counter register is incremented with each high to low transition on the T <sub>1</sub> pin.         Example:       Initialize and start event counter. Assume overflow is desired with first T <sub>1</sub> input. STARTC: EN TCNTI ;ENABLE COUNTER INTERRUPT MOV A, # OFFH ;MOVE 'FF' HEX (ONES) TO ;ACC MOV T,A ;MOVE ONES TO COUNTER STRT CNT ;INPUT AND START         RTT Start Timer       Opcode:       0 1 0 1 0 1 0 1         Timer accumulation is initiated in the timer register. The register is incremented every 3 instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register not.         Example:       Initialize and start timer. STARTT: EN TCNTI ;ENABLE TIMER INTERRUPT CLR A ;MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Event Counter                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| event-counter register is incremented with each high to low transition on the T1 pin.         Example:       Initialize and start event counter. Assume overflow is desired with first T1 input.         STARTC: EN TCNTI       ;ENABLE COUNTER INTERRUPT         MOV A, #OFFH       ;MOVE 'FF' HEX (ONES) TO         ;ACC       ;MOV T,A         STRT CNT       ;INPUT AND START         TT Start Timer       Opcode:         0 1 0 1       0 1 0 1         Timer accumulation is initiated in the timer register. The register is incremented every 3 instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register not.         Example:       Initialize and start timer.         STARTT: EN TCNTI       ;ENABLE TIMER INTERRUPT         CLR A       ;CLEAR ACC TO ZEROS         MOV T,A       ;MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0100 0101                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| STARTC: EN TCNTI       ;ENABLE COUNTER INTERRUPT         MOV A, # OFFH       ;MOVE 'FF' HEX (ONES) TO         ;ACC       ;MOV T,A         STRT CNT       ;INPUT AND START         TT Start Timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| MOV A, #OFFH       ;MOVE 'FF' HEX (ONES) TO         ;ACC       MOV T,A         STRT CNT       ;INPUT AND START         T T Start Timer       Initialize and start timer.         Opcode:       0 1 0 1 0 1         Timer accumulation is initiated in the timer register. The register is incremented every 3 instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register not.         Example:       Initialize and start timer.         STARTT: EN TCNTI       ;ENABLE TIMER INTERRUPT         CLR A       :CLEAR ACC TO ZEROS         MOV T,A       ;MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| ACC         MOV T,A       ;MOVE ONES TO COUNTER         STRT CNT       ;INPUT AND START         T T Start Timer       Timer accumulation is initiated in the timer register. The register is incremented every 3 instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register not.         Example:       Initialize and start timer.         STARTT: EN TCNTI       ;ENABLE TIMER INTERRUPT         CLR A       :CLEAR ACC TO ZEROS         MOV T,A       ;MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| MOV T,A       ;MOVE ONES TO COUNTER         STRT CNT       ;INPUT AND START         T T Start Timer       Image: Composition of the time     | MOV A, #OFFH                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| STRT CNT       ;INPUT AND START         TT Start Timer       Opcode:       0 1 0 1 0 1 0 1         Timer accumulation is initiated in the timer register. The register is incremented every 3 instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register not.         Example:       Initialize and start timer.         STARTT: EN TCNTI       ;ENABLE TIMER INTERRUPT         CLR A       :CLEAR ACC TO ZEROS         MOV T,A       ;MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Opcode:       0 1 0 1       0 1 0 1         Timer accumulation is initiated in the timer register. The register is incremented every 3 instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register not.         Example:       Initialize and start timer.<br>STARTT: EN TCNTI<br>CLR A       ENABLE TIMER INTERRUPT<br>CLEAR ACC TO ZEROS<br>MOV T,A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | MOV T.A                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Timer accumulation is initiated in the timer register. The register is incremented every 3 instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register not.         Example:       Initialize and start timer.         STARTT: EN TCNTI       ;ENABLE TIMER INTERRUPT         CLR A       :CLEAR ACC TO ZEROS         MOV T,A       ;MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ,                                                                                                                                                                                               | ;MOVE ONES TO COUNTER                                                                                                                                                                                                                                                                                                                                                                                                                |
| <b>Example:</b> Initialize and start timer.         STARTT: EN TCNTI       ;ENABLE TIMER INTERRUPT         CLR A       :CLEAR ACC TO ZEROS         MOV T,A       ;MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | STRT CNT                                                                                                                                                                                        | ;MOVE ONES TO COUNTER                                                                                                                                                                                                                                                                                                                                                                                                                |
| instruction cycles. The prescaler which counts the 32 cycles is cleared but the timer register not.         Example:       Initialize and start timer.         STARTT: EN TCNTI       ;ENABLE TIMER INTERRUPT         CLR A       :CLEAR ACC TO ZEROS         MOV T,A       ;MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | STRT CNT                                                                                                                                                                                        | ;MOVE ONES TO COUNTER                                                                                                                                                                                                                                                                                                                                                                                                                |
| Example:       Initialize and start timer.         STARTT: EN TCNTI       ;ENABLE TIMER INTERRUPT         CLR A       :CLEAR ACC TO ZEROS         MOV T,A       ;MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | STRT CNT                                                                                                                                                                                        | ;MOVE ONES TO COUNTER<br>;INPUT AND START                                                                                                                                                                                                                                                                                                                                                                                            |
| CLR A :CLEAR ACC TO ZEROS<br>MOV T,A ;MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | STRT CNT<br>ner<br>0 1 0 1 0 1 0 1<br>Timer accumulation is initiated in<br>instruction cycles. The prescaler wh                                                                                | ;MOVE ONES TO COUNTER<br>;INPUT AND START<br>the timer register. The register is incremented every 32                                                                                                                                                                                                                                                                                                                                |
| CLR A :CLEAR ACC TO ZEROS<br>MOV T,A ;MOVE ZEROS TO TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | STRT CNT<br>her<br>0 1 0 1 0 1 0 1<br>Timer accumulation is initiated in<br>instruction cycles. The prescaler wh<br>not.                                                                        | ;MOVE ONES TO COUNTER<br>;INPUT AND START<br>the timer register. The register is incremented every 32                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | STRT CNT<br>her<br>0 1 0 1       0 1 0 1         Timer accumulation is initiated in instruction cycles. The prescaler wh not.         Initialize and start timer.                               | ;MOVE ONES TO COUNTER<br>;INPUT AND START<br>the timer register. The register is incremented every 32<br>tich counts the 32 cycles is cleared but the timer register is                                                                                                                                                                                                                                                              |
| STRT T ;START TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | o 1 0 1       0 1 0 1         Timer accumulation is initiated in instruction cycles. The prescaler wh not.         Initialize and start timer.         STARTT: EN TCNTI                         | ;MOVE ONES TO COUNTER<br>;INPUT AND START<br>the timer register. The register is incremented every 32<br>ich counts the 32 cycles is cleared but the timer register is<br>;ENABLE TIMER INTERRUPT                                                                                                                                                                                                                                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | STRT CNT<br>ner<br>0 1 0 1 0 1 0 1<br>Timer accumulation is initiated in<br>instruction cycles. The prescaler wh<br>not.<br>Initialize and start timer.<br>STARTT: EN TCNTI<br>CLR A<br>MOV T,A | ;MOVE ONES TO COUNTER<br>;INPUT AND START<br>the timer register. The register is incremented every 32<br>ich counts the 32 cycles is cleared but the timer register is<br>;ENABLE TIMER INTERRUPT<br>:CLEAR ACC TO ZEROS<br>;MOVE ZEROS TO TIMER                                                                                                                                                                                     |
| Opcode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                 | Disable interrupt, but jump to interverflows in register 7.<br>START: DIS TCNTI<br>CLR A<br>MOV T,A<br>MOV R7,A<br>STRT T<br>MAIN: JTF COUNT<br>JMP MAIN<br>COUNT: INC R7<br>MOV A,R7<br>JB3 INT<br>JMP MAIN<br>INT: STOP TCNT<br>JMP 7H<br>Event Counter<br>0 1 0 0 0 1 0 1<br>The TEST 1 (T <sub>1</sub> ) pin is enabled as<br>event-counter register is incremented<br>Initialize and start event counter. A<br>STARTC: EN TCNTI |

#### STOP TCNT Stop Timer/Event Counter

#### SWAP A Swap Nibbles Within Accumulator

| Opcode:  | 0 1 0 0 0 1 1 1                                                                 |                                          |
|----------|---------------------------------------------------------------------------------|------------------------------------------|
|          | Bits 0-3 of the accumulator are sw<br>$(A_{4-7}) \longleftrightarrow (A_{0-3})$ | vapped with bits 4-7 of the accumulator. |
| Example: | Pack bits 0-3 of locations 50-51 in                                             | to location 50.                          |
| -        | PCKDIG: MOV R0, #50                                                             | ;MOVE '50' DEC TO REG 0                  |
|          | MOV R1,#51                                                                      | ;MOVE '51' DEC TO REG 1                  |
|          | XCHD A,@R0                                                                      | ;EXCHANGE BIT 0-3 OF ACC                 |
|          |                                                                                 | ;AND LOCATION 50                         |
|          | SWAP A                                                                          | ;SWAP BITS 0-3 AND 4-7 OF ACC            |
|          | XCHD A,@ R1                                                                     | EXCHANGE BITS 0-3 OF ACC AND             |
|          |                                                                                 | LOCATION 51                              |
|          | MOV @R0,A                                                                       | MOVE CONTENTS OF ACC TO                  |
|          |                                                                                 | ;LOCATION 51                             |

XCH ARr Exchange Accumulator-Register Contents

| Opcode:  | 0 0 1 0 1 r <sub>2</sub> r <sub>1</sub> r <sub>0</sub>  |                                                                            |
|----------|---------------------------------------------------------|----------------------------------------------------------------------------|
|          | The contents of the accumulator and the (A) $\iff$ (Rr) | he contents of working register 'r' are exchanged. $r = 0-7$               |
| Example: | Move PSW contents to Reg 7 without XCHAR7: XCH A,R7     | losing accumulator contents.<br>;EXCHANGE CONTENTS OF REG 7<br>:AND ACC    |
|          | MOV A,PSW<br>XCH, A,R7                                  | ;MOVE PSW CONTENTS TO ACC<br>;EXCHANGE CONTENTS OF REG 7<br>;AND ACC AGAIN |

XCH A,@Rr Exchange Accumulator and Data Memory Contents

| Opcode:  | 0010 000r                                                                                                               |                                                                                                            |
|----------|-------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|
|          | The contents of the accumulator and th<br>bits 0-7 of register 'r' are exchanged. R<br>(A) $\longleftrightarrow$ ((Rr)) | the contents of the data memory location addressed by the degister 'r' contents are unaffected.<br>r = 0-1 |
| Example: | Decrement contents of location 52.                                                                                      |                                                                                                            |
| -        | DEC 52: MOV R0, #52                                                                                                     | ;MOVE '52' DEC TO ADDRESS                                                                                  |
|          |                                                                                                                         | ;REG 0                                                                                                     |
|          | XCH A,@R0                                                                                                               | ;EXCHANGE CONTENTS OF ACC                                                                                  |
|          |                                                                                                                         | ;AND LOCATION 52                                                                                           |
|          | DEC A                                                                                                                   | ;DECREMENT ACC CONTENTS                                                                                    |
|          | XCH A,@R0                                                                                                               | EXCHANGE CONTENTS OF ACC                                                                                   |
|          |                                                                                                                         | AND LOCATION 52 AGAIN                                                                                      |



| 0011 000r                                                                    |                                                                                                                                                                                                                               |
|------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                              | -3 of the accumulator with bits 0-3 of the data memory egister 'r'. Bits 4-7 of the accumulator, bits 4-7 of the data s of register 'r' are unaffected.<br>r = 0-1                                                            |
| Assume program counter contents<br>XCHNIB: MOV R0,#23<br>CLR A<br>XCHD A,@R0 | have been stacked in locations 22-23.<br>;MOVE '23' DEC TO REG 0<br>;CLEAR ACC TO ZEROS<br>;EXCHANGE BITS 0–3 OF ACC<br>;AND LOCATION 23 (BITS 8–11<br>;OF PC ARE ZEROED, ADDRESS<br>;REFERS TO PAGE 0)                       |
|                                                                              | This instruction exchanges bits 0-<br>location addressed by bits 0-7 of r<br>memory location, and the contents<br>$(A_{0-3}) \leftrightarrow ((Rr_{0-3}))$<br>Assume program counter contents<br>XCHNIB: MOV R0, #23<br>CLR A |

#### XCHD A,@Rr Exchange Accumulator and Data Memory 4-bit Data

| XRL A,Rr | Logical XOR | Accumulator | With F | Register | Mask |
|----------|-------------|-------------|--------|----------|------|
|----------|-------------|-------------|--------|----------|------|

| Opcode:  | 1 1 0 1 1 r <sub>2</sub> r <sub>1</sub> r <sub>0</sub> |                                                            |
|----------|--------------------------------------------------------|------------------------------------------------------------|
|          | Data in the accumulator is E                           | EXCLUSIVE ORed with the mask contained in working register |
|          | $(A) \longleftrightarrow (A) \text{ XOR } (Rr)$        | r = 0-7                                                    |
| Example: | XORREG: XRL A,R5                                       | ;'XOR' ACC CONTENTS WITH<br>;MASK IN REG 5                 |

| XRL A,@Rr | Logical XOR | Accumulator | With Memory | v Mask |
|-----------|-------------|-------------|-------------|--------|
|-----------|-------------|-------------|-------------|--------|

| Opcode:  | 1 1 0 1 0 0 0 r                                                                                                |                                                                             |
|----------|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|
|          | Data in the accumulator is EXCLUS<br>location address by register 'r', bits<br>(A) $\leftarrow$ (A) XOR ((Rr)) | SIVE ORed with the mask contained in the data memory $0-7$ .<br>r = $0-1$   |
| Example: | XORDM: MOV R1,#20H<br>XRL A,@R1                                                                                | ;MOVE '20' HEX TO REG 1<br>;'XOR' ACC CONTENTS WITH MASK<br>;IN LOCATION 32 |

| XRL A,#data, L | Logical XOR Accumulator | With Immediate Mask |
|----------------|-------------------------|---------------------|
|----------------|-------------------------|---------------------|

| Opcode:  | 1 1 0 1 0 0 1 1 • d <sub>7</sub> d                                                                            | $_{6}$ d <sub>5</sub> d <sub>4</sub> d <sub>3</sub> d <sub>2</sub> d <sub>1</sub> d <sub>0</sub> |
|----------|---------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|
|          | <ul> <li>This is a 2-cycle instruction. Data in a tely-specified mask.</li> <li>(A) ← (A) XOR data</li> </ul> | the accumulator is EXCLUSIVE ORed with an immedi-                                                |
| Example: | XORID: XRL A, #HEXTEN                                                                                         | ;XOR CONTENTS OF ACC WITH<br>;MASK EQUAL VALUE OF SYMBOL<br>;'HEXTEN'                            |

#### UPI-41A/41AH/42/42AH USER'S MANUAL

### CHAPTER 4 SINGLE-STEP AND PROGRAMMING POWER-DOWN MODES

#### SINGLE-STEP

The UPI family has a single-step mode which allows the user to manually step through his program one instruction at a time. While stopped, the address of the next instruction to be fetched is available on PORT 1 and the lower 2 bits of PORT 2. The single-step feature simplifies program debugging by allowing the user to easily follow program execution. Figure 4-1 illustrates a recommended circuit for singlestep operation, while Figure 4-2 shows the timing relationship between the SYNC output and the SS input. During single-step operation, PORT 1 and part of PORT 2 are used to output address information. In order to retain the normal I/O functions of PORTS 1 and 2, a separate latch can be used as shown in Figure 4-3.



Figure 4-1. Single-Step Circuit



Figure 4-2. Single-Step Timing

### intel



Figure 4-3. Latching Port Data

#### Timing

The sequence of single-step operation is as follows:

- The processor is requested to stop by applying a low level on SS. The SS input should not be brought low while SYNC is high. (The UPI samples the SS pin in the middle of the SYNC pulse).
- 2) The processor responds to the request by stopping during the instruction fetch portion of the next instruction. If a double cycle instruction is in progress when the single-step command is received, both cycles will be completed before stopping.
- 3) The processor acknowledges it has entered the stopped state by raising SYNC high. In this state, which can be maintained indefinitely, the 10-bit address of the next instruction to be fetched is preset on PORT 1 and the lower 2 bits of PORT 2.
- 4)  $\overline{SS}$  is then raised high to bring the processor out of the stopped mode allowing it to fetch the next instruction. The exit from stop is indicated by the processor bringing SYNC low.

5) To stop the processor at the next instruction SS must be brought low again before the next SYNC pulse the circuit in Figure 4-1 uses the trailing edge of the previous pulse. If SS is left high, the processor remains in the "RUN" mode.

Figure 4-1 shows a schematic for implementing singlestep. A single D-type flip-flop with preset and clear is used to generate SS. In the RUN mode SS is held high by keeping the flip-flop preset (preset has precedence over the clear input). To enter single-step, preset is removed allowing SYNC to bring SS low via the clear input. Note that SYNC must be buffered since the SN7474 is equivalent to 3 TTL loads.

The processor is now in the stopped state. The next instruction is initiated by stoppe state. The next instruction is initiated by clocking "1" the flip-flop. This "1" will not appear on  $\overline{SS}$  unless SYNC is high (I.e., clear must be removed from the flip-flop). In response to  $\overline{SS}$  going high, the processor begins an instruction fetch which brings SYNC low.  $\overline{SS}$  is then reset through the clear input and the processor again enters the stopped state.

#### UPI-41A/41AH/42/42AH USER'S MANUAL

#### **EXTERNAL ACCESS**

The UPI family has an External Access mode (EA) which puts the processor into a test mode. This mode allows the user to disable the internal program memory and execute from external memory. External Access mode is useful in testing because it allows the user to test the processor's functions directly. It is only useful for testing since this mode uses  $D_0-D_7$ , PORTS 10-17 and PORTS 20-22.

This mode is invoked by connecting the EA pin to 5V. The 11-bit current program counter contents then come out on PORTS 10–17 and PORTS 20–22 after the SYNC output goes high. (PORT 10 is the least significant bit.) The desired instruction opcode is placed on  $D_0-D_7$  before the start of state  $S_1$ . During state  $S_1$ , the opcode is sampled from  $D_0-D_7$  and subsequently executed in place of the internal program memory contents.

The program counter contents are multiplexed with the I/O port data on PORTS 10–17 and PORTS 20–22. The I/O port data may be demultiplexed using an external latch on the rising edge of SYNC. The program counter contents may be demultiplexed similarly using the trailing edge of SYNC.

Reading and/or writing the Data Bus Buffer registers is still allowed although only when  $D_0-D_7$  are not being sampled for opcode data. In practice, since this sampling time is not known externally, reads or writes on the system bus are done during SYNC high time. Approximately 600 ns are available for each read or write cycle.

#### POWER DOWN MODE (UPI-41AH/42AH ONLY)

Extra circuitry is included in the UPI-41AH/42AH version to allow low-power, standby operation. Power is removed from all system elements except the inter-

nal data RAM in the low-power mode. Thus the contents of RAM can be maintained and the device draws only 10 to 15% of its normal power.

The  $V_{CC}$  pin serves as the 5V power supply pin for all of the UPI-41AH/42AH version's circuitry except the data RAM array. The  $V_{DD}$  pin supplies only the RAM array. In normal operation, both  $V_{CC}$  and  $V_{DD}$  are connected to the same 5V power supply.

To enter the Power-Down mode, the  $\overline{\text{RESET}}$  signal to the UPI is asserted. This ensures the memory will not be inadvertently altered by the UPI during powerdown. The V<sub>CC</sub> pin is then grounded while V<sub>DD</sub> is maintained at 5V. Figure 4-4 illustrates a recommended Power-Down sequence. The sequence typically occurs as follows:

- Imminent power supply failure is detected by user defined circuitry. The signal must occur early enough to guarantee the UPI-41AH/42AH can save all necessary data before V<sub>CC</sub> falls outside normal operating tolerance.
- 2) A "Power Failure" signal is used to interrupt the processor (via a timer overflow interrupt, for instance) and call a Power Failure service routine.
- 3) The Power Failure routine saves all important data and machine status in the RAM array. The routine may also initiate transfer of a backup supply to the V<sub>DD</sub> pin and indicate to external circuitry that the Power Failure routine is complete.
- 4) A RESET signal is applied by external hardware to guarantee data will not be altered as the power supply falls out of limits. RESET must be low until V<sub>CC</sub> reaches ground potential.

Recovery from the Power-Down mode can occur as any other power-on sequence. An external 1  $\mu$ fd capacitor on the RESET input will provide the necessary initialization pulse.



Figure 4-4. Power-Down Sequence



### CHAPTER 5 SYSTEM OPERATION

#### **BUS INTERFACE**

The UPI-41A/41AH/42/42AH Microcomputer functions as a peripheral to a master processor by using the data bus buffer registers to handle data transfers. The DBB configuration is illustrated in Figure 5-1. The UPI Microcomputer's 8 three-state data lines  $(D_7-D_0)$  connect directly to the master processor's data bus. Data transfer to the master is controlled by 4 external inputs to the UPI:

- A0 Address Input signifying command or data
- CS Chip Select
- $\overline{RD}$  Read strobe
- $\overline{WR}$  Write strobe



Figure 5-1. Data Bus Register Configuration

The master processor addresses the UPI-41A/41AH/ 42/42AH Microcomputer as a standard peripheral device. Table 5-1 shows the conditions for data transfer:

| Table 5-1. Data Transfer Controls |
|-----------------------------------|
|-----------------------------------|

| CS | A <sub>0</sub> | RD | WR | Condition                       |
|----|----------------|----|----|---------------------------------|
| 0  | 0              | 0  | 1  | Read DBBOUT                     |
| 0  | 1              | 0  | 1  | Read STATUS                     |
| 0  | 0              | 1  | 0  | Write DBBIN data, set $F_1 = 0$ |
| 0  | 1              | 1  | 0  | Write DBBIN command set         |
|    |                |    |    | F <sub>1</sub> = 1              |
| 1  | х              | х  | х  | Disable DBB                     |

#### **Reading the DBBOUT Register**

The sequence for reading the DBBOUT register is shown in Figure 5-2. This operation causes the 8-bit contents of the DBBOUT register to be placed on the system Data Bus. The OBF flag is cleared automatically.

#### **Reading STATUS**

The sequence for reading the UPI Microcomputer's 8 STATUS bits is shown in Figure 5-3. This operation causes the 8-bit STATUS register contents to be placed on the system Data Bus as shown.



Figure 5-3. Status Read



Figure 5-4. Writing Data to DBBIN

### Write Data to DBBIN

The sequence for writing data to the DBBIN register is shown in Figure 5-4. This operation causes the system Data Bus contents to be transferred to the DBBIN register and the IBF flag is set. Also, the F<sub>1</sub> flag is cleared (F<sub>1</sub> = 0) and an interrupt request is generated. When the IBF interrupt is enabled, a jump to location 3 will occur. The interrupt request is cleared upon entering the IBF service routine or by a system RESET input.

#### Writing Commands to DBBIN

The sequence for writing commands to the DBBIN register is shown in Figure 5-5. This sequence is identical to a data write except that the  $A_0$  input is latched in the  $F_1$  flag ( $F_1 = 1$ ). The IBF flag is set and an interrupt request is generated when the master writes a command to DBB.

#### **Operations of Data Bus Registers**

The UPI-41A/41AH/42/42AH Microcomputer controls the transfer of DBB data to its accumulator by executing INput and OUTput instructions. An IN A,DBB instruction causes the contents to be transferred to the UPI accumulator and the IBF flag is cleared.

The OUT DBB,A instruction causes the contents of the accumulator to be transferred to the DBBOUT register. The OBF flag is set.

The UPI's data bus buffer interface is applicable to a variety of microprocessors including the 8086, 8085AH, 8080, and 8048.

A description of the interface to each of these processors follows.



Figure 5-5. Writing Commands to DBBIN

#### **DESIGN EXAMPLES**

#### 8085AH Interface

Figure 5-6 illustrates an 8085AH system using a UPI-41A/41AH/42/42AH. The 8085AH system uses a multiplexed address and data bus. During I/O the 8 upper address lines ( $A_8-A_{15}$ ) contain the same I/O address as the lower 8 address/data lines ( $A_0-A_7$ ); therefore I/O address decoding is done using only the upper 8 lines to eliminate latching of the address. An 8205 decoder provides address decoding for both the UPI and the 8237. Data is transferred using the two DMA handshaking lines of PORT 2. The 8237 performs the actual bus transfer operation. Using the UPI-41A/41AH/42/42AH's OBF master interrupt, the UPI notifies the 8085AH upon transfer completion using the RST 5.5 interrupt input. The IBF master interrupt is not used in this example.

#### 8088 Interface

Figure 5-7 illustrates a UPI-41A/41AH/42/42AH interface to an 8088 minimum mode system. Two 8-bit latches are used to demultiplex the address and data bus. The address bus is 20-lines wide. For I/O only, the lower 16 address lines are used, providing an addressing range of 64K. UPI address selection is accomplished using an 8205 decoder. The  $A_0$  address line of the bus is connected to the corresponding UPI input for register selection. Since the UPI is polled by the 8088, neither DMA nor master interrupt capabilities of the UPI are used in the figure.

#### 8086 Interface

The UPI-41A/41AH/42/42AH can be used on an 8086 maximum mode system as shown in Figure 5-8. The address and data bus is demultiplexed using three



#### Figure 5-6. 8085AH-UPI System



Figure 5-7. 8088-UPI Minimum Mode System

#### UPI-41A/41AH/42/42AH USER'S MANUAL



Figure 5-8. 8086-UPI Maximum Mode Systems

8282 latches providing separate address and data buses. The address bus is 20-lines wide and the data bus is 16-lines wide. Multiplexed control lines are decoded by the 8288. The UPI's  $\overline{CS}$  input is provided by linear selection. Note that the UPI is both I/O mapped and memory mapped as a result of the linear addressing technique. An address decoder may be used to limit the UPI-41A/41AH/42/42AH to a specific I/O mapped address. Address line A<sub>1</sub> is connected to the UPI's A<sub>0</sub> input. This insures that the registers of the UPI will have even I/O addresse. Data will be transferred on D<sub>0</sub>-D<sub>7</sub> lines only. This allows the I/O registers to be accessed using byte manipulation instructions.

#### 8080 Interface

Figure 5-9 illustrates the interface to an 8080A system. In this example, a crystal and capacitor are used for UPI-41A/41AH/42/42AH timing reference and power-on RESET. If the 2-MHz 8080A 2-phase clock were used instead of the crystal, the UPI-41A/41AH/42/42AH would run at only 16% full speed.

The  $A_0$  and  $\overline{CS}$  inputs are direct connections to the 8080 address bus. In larger systems, however, either of these inputs may be decoded from the 16 address lines.

The  $\overline{RD}$  and  $\overline{WR}$  inputs to the UPI can be either the  $\overline{IOR}$  and  $\overline{IOW}$  or the  $\overline{MEMR}$  and  $\overline{MEMR}$  signals depending on the I/O mapping technique to be used.

The UPI can be addressed as an I/O device using INput and OUTput instructions in 8080 software.

#### 8048 Interface

Figure 5-10 shows the UPI interface to an 8048 master processor.

The 8048  $\overline{RD}$  and  $\overline{WR}$  outputs are directly compatible with the UPI. Figure 5-11 shows a distributed processing system with up to seven UPI's connected to a single 8048 master processor.

In this configuration the 8048 uses PORT 0 as a data bus. I/O PORT 2 is used to select one of the seven

### intel



Figure 5-9. 8080A-UPI Interface





UPI's when data transfer occurs. The UPI's are programmed to handle isolated tasks and, since they operate in parallel, system throughput is increased.

### GENERAL HANDSHAKING PROTOCOL

- 1) Master reads STATUS register ( $\overline{RD}$ ,  $\overline{CS}$ ,  $\underline{A_0} = (0, 0, 1)$ ) in polling or in response to either an  $\overline{IBF}$  or an OBF interrupt.
- 2) If the UPI DBBIN register is empty (IBF flag = 0), Master writes a word to the DBBIN register ( $\overline{WR}$ ,

 $\overline{CS}$ ,  $A_0 = (0, 0, 1)$  or (0, 0, 0)). If  $A_0 = 1$ , write command word, set  $F_1$ . If  $A_0 = 0$ , write data word,  $F_1 = 0$ .

- 3) If the UPI DBBOUT register is full (OBF flag = 1), Master reads a word from the DBBOUT register  $(\overline{RD}, \overline{CS}, A_0 = (0,0, 0)).$
- 4) UPI recognizes IBF (via IBF interrupt or JNIBF). Input data or command word is processed, depending on F1; IBF is reset. Repeat step 1 above.
- 5) UPI recognizes OBF flag = 0 (via JOBF). Next word is output to DBBOUT register, OBF is set. Repeat step 1 above.

#### UPI-41A/41AH/42/42AH USER'S MANUAL



Figure 5-11. Distributed Processor System



### CHAPTER 6 APPLICATIONS

#### ABSTRACTS

The UPI-41A/41AH/42/42AH is designed to fill a wide variety of low to medium speed peripheral interface applications where flexibility and easy implementation are important considerations. The following examples illustrate some typical applications.

#### **Keyboard Encoder**

Figure 6-1 illustrates a keyboard encoder configuration using the UPI and the 8243 I/O expander to scan a 128-key matrix. The encoder has switch matrix scanning logic, N-key rollover logic, ROM look-up table, FIFO character buffer, and additional outputs for display functions, control keys or other special functions.

PORT 1 and PORTs 4–7 provide the interface to the keyboard. PORT 1 lines are set one at a time to select the various key matrix rows.

When a row is energized all 16 columns (i.e., PORTs 4-7 inputs) are sampled to determine if any switch in the row is closed. The scanning software is code effi-

cient because the UPI instruction set includes individual bit set/clear operations and expander PORTs 4-7 can be directly addressed with single, 2-byte instructions. Also, accumulator bits can be tested in a single operation. Scan time for 128 keys is about 10 ms. Each matrix point has a unique binary code which is used to address ROM when a key closure is detected. Page 3 of ROM contains a look-up table with useable codes (i.e., ASCII, EBCDIC, etc.) which correspond to each key. When a valid key closure is detected the ROM code corresponding to that key is stored in a FIFO buffer in data memory for transfer to the master processor. To avoid stray noise and switch bounce, a key closure must be detected on two consecutive scans before it is considered valid and loaded into the FIFO buffer. The FIFO buffer allows multiple keys to be processed as they are depressed without regard to when they are released, a condition known as N-key rollover.

The basic features of this encoder are fairly standard and require only about 500 bytes of memory. Since the UPI is programmable and has additional memory capacity it can handle a number of other functions. For example, special keys can be programmed to give an entry on closing as well as opening. Also, I/O lines are



Figure 6-1. Keyboard Encoder Configuration

62

#### UPI-41A/41AH/42/42AH USER'S MANUAL

available to control a 16-digit, 7-segment display. The UPI can also be programmed to recognize special combinations of characters such as commands, then transfer only the decoded information to the master processor.

#### **Matrix Printer Interface**

The matrix printer interface illustrated in Figure 6-2 is a typical application for the UPI. The actual printer mechanism could be any of the numerous dot-matrix types and similar configurations can be shown for drum, spherical head, daisy wheel or chain type printers.

The bus structure shown represents a generalized, 8-bit system bus configuration. The UPI's three-state inter-

face port and asynchronous data buffer registers allow it to connect directly to this type of system for efficient, two-way data transfer.

The UPI's two on-board I/O ports provide up to 16 input and output signals to control the printer mechanism. The timer/event counter is used for generating a timing sequence to control print head position, line feed, carriage return, and other sequences. The on-board program memory provides character generation for  $5 \times 7$ ,  $7 \times 9$ , or other dot matrix formats. As an added feature a portion of the data memory can be used as a FIFO buffer so that the master processor can send a block of data at a high rate. The UPI can then output characters from the buffer at a rate the printer can accept while the master processor returns to other tasks.



Figure 6-2. Matrix Printer Controller



The 8295 Printer Controller is an example of an UPI preprogrammed as a dot matrix printer interface.

#### **Tape Cassette Controller**

Figure 6-3 illustrates a digital cassette interface which can be implemented with the UPI. Two sections of the tape transport are controlled by the UPI: digital data/ command logic, and motor servo control.

The motor servo requires a speed reference in the form of a monostable pulse whose width is proportional to the desired speed. The UPI monitors a prerecorded clock from the tape and uses its on-board interval timer to generate the required speed reference pulses at each clock transition.

Recorded data from the tape is supplied serially by the data/command logic and is converted to 8-bit words by the UPI, then transferred to the master processor. At 10 ips tape speed the UPI can easily handle the 8000 bps data rate. To record data, the UPI uses the two input lines to the data/command logic which control the flux direction in the recording head. The UPI also monitors 4 status lines from the tape transport including: end of tape, cassette inserted, busy, and write permit. All control signals can be handled by the UPI's two I/O ports.

#### Universal I/O Interface

Figure 6-4 shows an I/O interface design based on the UPI. This configuration includes 12 parallel I/O lines and a serial (RS232C) interface for full duplex data transfer up to 1200 baud. This type of design can be used to interface a master processor to a broad spectrum of peripheral devices as well as to a serial communication channel.

PORT 1 is used strictly for I/O in this example while PORT 2 lines provide five functions:

- P<sub>23</sub>-P<sub>20</sub> I/O lines (bidirectional)
- P<sub>24</sub> Request to send (RTS)
- P<sub>25</sub> Clear to send (CTS)
- P<sub>26</sub> Interrupt to master
- P<sub>27</sub> Serial data out

The parallel I/O lines make use of the bidirectional port structure of the UPI. Any line can function as an input or output. All port lines are automatically initialized to 1 by a system RESET pulse and remain latched. An external TTL signal connected to a port line will override the UPI's 50 K $\Omega$  internal pull-up so that an INPUT instruction will correctly sample the TTL signal.



Figure 6-3. Tape Transport Controller

64

Four PORT 2 lines function as general I/O similar to PORT 1. Also, the RTS signal is generated on PORT 2 under software control when the UPI has serial data to send. The CTS signal is monitored via PORT 2 as an enable to the UPI to send serial data. A PORT 2 line is also used as a software generated interrupt to the master processor. The interrupt functions as a service request when the UPI has a byte of data to transfer or when it is ready to receive. Alternatively, the EN FLAGS instruction could be used to create the OBF and IBF interrupts on P<sub>24</sub> and P<sub>25</sub>.

The RS232C interface is implemented using the TEST 0 pin as a receive input and a PORT 2 pin as a transmit output. External packages  $(A_0, A_1)$  are used to provide RS232C drive requirements. The serial receive software is interrupt driven and uses the on-chip timer to perform time critical serial control. After a start bit is detected the interval timer can be preset to generate an interrupt at the proper time for sampling the serial bit stream. This eliminates the need for software timing

#### UPI-41A/41AH/42/42AH USER'S MANUAL

loops and allows the processor to proceed to other tasks (i.e., parallel I/O operations) between serial bit samples. Software flags are used so the main program can determine when the interrupt driven receive program has a character assembled for it.

This type of configuration allows system designers flexibility in designing custom I/O interfaces for specific serial and parallel I/O applications. For instance, a second or third serial channel could be substituted in place of the parallel I/O if required. The UPI's data memory can buffer data and commands for up to 4 low-speed channels (110 baud teletypewriter, etc.)

#### **Application Notes**

The following application notes illustrate the various applications of the UPI family. Other related publications including the *Microcontroller Handbook* are available through the Intel Literature Department.



Figure 6-4. Universal I/O Interface